aotoyae

[JS] 프로그래머스 : 소수 찾기 12921 본문

Coding Test

[JS] 프로그래머스 : 소수 찾기 12921

aotoyae 2024. 2. 24. 03:09

 

 

📝 문제

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

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

 

🫠 나의 풀이

function solution(n) {
  let answer = 0;

  for (let i = 2; i <= n; i++) {
    if (isPrimeNumber(i)) answer++;
  }

  return answer;
}

function isPrimeNumber(number) {
  for (let i = 2; i < number; i++) {
    if (number % i === 0) return false;
  }

  return true;
}

 

시간 초과.. 🫠

 

🧞‍♂️ 다른 사람의 풀이

function solution(n) {
  let array = Array(n + 1)
    .fill(true)
    .fill(false, 0, 1);
  let count = 0;

  for (let i = 2; i <= n; i++) {
    if (array[i]) {
      count++;
      for (let j = i * i; j <= n; j += i) {
        array[j] = false;
      }
    }
  }

  return count;
}

 

 

 

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

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr