💡풀이
import java.util.stream.IntStream;
class Solution {
public int solution(int n) {
return (int) IntStream.rangeClosed(2, n)
.filter(this::isPrimeNumber)
.count();
}
boolean isPrimeNumber(int n) {
for (int i = 2; i <= Math.sqrt(n); i++) {
if (n % i == 0) return false;
}
return true;
}
}
💡풀이 2
📖새로 배운 부분
- 어떤 수의 약수들은 항상 쌍을 이루기 때문에
분기점이 되는 해당 수의 제곱근까지만 약수를 구하고 한쌍의 약수를 함께 count 해주면 된다.
💡해당 내용을 정리한 글
[Java] 약수의 개수를 구하는 효율적인 알고리즘 정리
약수 구하기 알고리즘코딩테스트나 알고리즘 문제를 풀다 보면 약수를 구하는 문제를 자주 만나게 됩니다하지만 큰 수의 경우 비효율적인 로직으로 인해 시간 초과에 부딪히는 경우가 다반사
devoks.tistory.com
GitHub - okjunghyeon/Programmers_CodingTest: 프로그래머스 관련 코딩테스트 문제를 풀이한 저장소입니다.
프로그래머스 관련 코딩테스트 문제를 풀이한 저장소입니다. Contribute to okjunghyeon/Programmers_CodingTest development by creating an account on GitHub.
github.com
'CodingTest > Programmers' 카테고리의 다른 글
[프로그래머스, Java] 옹알이 (2) (0) | 2025.07.18 |
---|---|
[프로그래머스, Java] 소수 만들기 (0) | 2025.07.18 |
[프로그래머스, Java] 과일 장수 (0) | 2025.07.18 |
[프로그래머스, Java] 덧칠하기 (0) | 2025.07.18 |
[프로그래머스, Java] 모의고사 (1) | 2025.07.17 |