본문 바로가기

Algorithm/프로그래머스

프로그래머스 level1 문제 : 소수 찾기(java)

반응형

문제 설명 : 


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

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


제한 조건 : 

1. n은 2이상 1000000이하의 자연수입니다.



아래와 처럼 구성했습니다.

ArrayList<Integer> arrayList = new ArrayList<>();
arrayList.add(2);

for(int i=3; i<=n; i++) {
boolean isOk = false;
for(int j=0; j<arrayList.size(); j++) {
if(i%arrayList.get(j) == 0) {
isOk = false;
break;
} else isOk = true;
}

if(isOk) arrayList.add(i);
}

return arrayList.size();



하지만!!!!!!!!!!!!!!!!!! 테스트는 다 통과했는데, 효율성은 통과하지 못하겠네요 뭐가 문제일까요...


효율성테스트 통과하는법 가르쳐주실분..



반응형