문제
1부터 입력받은 숫자 n 사이에 있는 소수의 개수를 반환하는 함수, solution을 만들어 보세요.
소수는 1과 자기 자신으로만 나누어지는 수를 의미합니다.
(1은 소수가 아닙니다.)
제한사항
- n은 2이상 1000000이하의 자연수입니다.
import java.util.ArrayList;
class Solution {
public int solution(int n) {
int answer = 0;
for(int i = 2; i <= n; i++) {
boolean isSosu = true;
for(int j = 2; j <= Math.sqrt(i); j++) {
if(i % j == 0) {
isSosu = false;
break;
}
}
if(isSosu) {
answer++;
}
}
return answer;
}
}
효율성 테스트까지 하기때문에, 뭐 그게 아니서라도 효율을 위해서, 제곱 방식을 꼭 알아두자.
출처
https://school.programmers.co.kr/learn/courses/30/lessons/12921