Post

소수 찾기

https://school.programmers.co.kr/learn/courses/30/lessons/12921

📔 문제 설명

1부터 입력받은 숫자 n 사이에 있는 소수의 개수를 반환하는 함수, solution을 만들어 보세요.

소수는 1과 자기 자신으로만 나누어지는 수를 의미합니다. (1은 소수가 아닙니다.)

💡 입출력 예

nresult
104
53

💻내가 작성한 코드

  • 테스트 케이스 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.