소수 찾기
https://school.programmers.co.kr/learn/courses/30/lessons/12921
📔 문제 설명
1부터 입력받은 숫자 n 사이에 있는 소수의 개수를 반환하는 함수, solution을 만들어 보세요.
소수는 1과 자기 자신으로만 나누어지는 수를 의미합니다. (1은 소수가 아닙니다.)
💡 입출력 예
n | result |
---|---|
10 | 4 |
5 | 3 |
💻내가 작성한 코드
- 테스트 케이스 10,11,12가 시간초과가 나오고 효율성 테스트를 통과하지 못하여 다른 사람들의 힌트를 보고
- 에라토스테네스의 체를 참고하여 풀이하였다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
function solution(n) {
const arr = Array(n + 1)
.fill(true)
.fill(false, 0, 2);
for (let i = 2; i * i <= n; i++) {
if (arr[i]) {
for (let j = i * i; j <= n; j += i) {
console.log(i, j);
arr[j] = false;
}
}
}
return arr.filter((e) => e).length;
}
This post is licensed under CC BY 4.0 by the author.