13af6ab5fSopenharmony_ci/* 23af6ab5fSopenharmony_ci * Copyright (c) 2024 Huawei Device Co., Ltd. 33af6ab5fSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 43af6ab5fSopenharmony_ci * you may not use this file except in compliance with the License. 53af6ab5fSopenharmony_ci * You may obtain a copy of the License at 63af6ab5fSopenharmony_ci * 73af6ab5fSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 83af6ab5fSopenharmony_ci * 93af6ab5fSopenharmony_ci * Unless required by applicable law or agreed to in writing, software 103af6ab5fSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 113af6ab5fSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 123af6ab5fSopenharmony_ci * See the License for the specific language governing permissions and 133af6ab5fSopenharmony_ci * limitations under the License. 143af6ab5fSopenharmony_ci */ 153af6ab5fSopenharmony_ci 163af6ab5fSopenharmony_ciexport class AccessNSieve { 173af6ab5fSopenharmony_ci static readonly n1: int = 3; 183af6ab5fSopenharmony_ci static readonly n2: int = 10000; 193af6ab5fSopenharmony_ci static readonly expected: int = 14302; 203af6ab5fSopenharmony_ci static isPrime: boolean[] = []; 213af6ab5fSopenharmony_ci 223af6ab5fSopenharmony_ci public setup(): void { 233af6ab5fSopenharmony_ci AccessNSieve.isPrime = new boolean[(1 << AccessNSieve.n1) * AccessNSieve.n2 + 1]; 243af6ab5fSopenharmony_ci } 253af6ab5fSopenharmony_ci 263af6ab5fSopenharmony_ci private static nsieve(m: int): int { 273af6ab5fSopenharmony_ci let count: int = 0; 283af6ab5fSopenharmony_ci 293af6ab5fSopenharmony_ci for (let i: int = 2; i <= m; i++) { 303af6ab5fSopenharmony_ci AccessNSieve.isPrime[i] = true; 313af6ab5fSopenharmony_ci } 323af6ab5fSopenharmony_ci 333af6ab5fSopenharmony_ci for (let i: int = 2; i <= m; i++) { 343af6ab5fSopenharmony_ci if (AccessNSieve.isPrime[i]) { 353af6ab5fSopenharmony_ci for (let k: int = i + i; k <= m; k += i) { 363af6ab5fSopenharmony_ci AccessNSieve.isPrime[k] = false; 373af6ab5fSopenharmony_ci } 383af6ab5fSopenharmony_ci count++; 393af6ab5fSopenharmony_ci } 403af6ab5fSopenharmony_ci } 413af6ab5fSopenharmony_ci return count; 423af6ab5fSopenharmony_ci } 433af6ab5fSopenharmony_ci 443af6ab5fSopenharmony_ci public static sieve(): int { 453af6ab5fSopenharmony_ci let sum: int = 0; 463af6ab5fSopenharmony_ci for (let i: int = 1; i <= AccessNSieve.n1; i++) { 473af6ab5fSopenharmony_ci let m: int = (1 << i) * AccessNSieve.n2; 483af6ab5fSopenharmony_ci sum += AccessNSieve.nsieve(m); 493af6ab5fSopenharmony_ci } 503af6ab5fSopenharmony_ci return sum; 513af6ab5fSopenharmony_ci } 523af6ab5fSopenharmony_ci 533af6ab5fSopenharmony_ci public run(): void { 543af6ab5fSopenharmony_ci let ret: int = AccessNSieve.sieve(); 553af6ab5fSopenharmony_ci assert ret == AccessNSieve.expected: "Invalid result"; 563af6ab5fSopenharmony_ci } 573af6ab5fSopenharmony_ci} 583af6ab5fSopenharmony_ci 593af6ab5fSopenharmony_cifunction main(): void { 603af6ab5fSopenharmony_ci let a = new AccessNSieve; 613af6ab5fSopenharmony_ci a.setup(); 623af6ab5fSopenharmony_ci a.run(); 633af6ab5fSopenharmony_ci} 64