문제 설명
약수의 개수가 세 개 이상인 수를 합성수라고 합니다. 자연수 n이 매개변수로 주어질 때 n이하의 합성수의 개수를 return하도록 solution 함수를 완성해주세요.
제한사항
1 ≤ n ≤ 100
입출력 예
n | result |
10 | 5 |
15 | 8 |
입출력 예 #1 : 10 이하 합성수는 4, 6, 8, 9, 10 로 5개입니다. 따라서 5를 return합니다.
입출력 예 #2 : 15 이하 합성수는 4, 6, 8, 9, 10, 12, 14, 15 로 8개입니다. 따라서 8을 return합니다.
나의 풀이
class Solution {
public int solution(int n) {
int answer = 0;
for(int i = 1; i <= n; i++){
int count = 0;
for(int j = 1; j <= n; j++){
if(i % j == 0){
count++;
}
}
if(count >= 3){
answer++;
}
}
return answer;
}
}
다른 풀이
import java.util.stream.IntStream;
class Solution {
public int solution(int n) {
return (int) IntStream.rangeClosed(1, n).filter(i -> (int) IntStream.rangeClosed(1, i).filter(i2 -> i % i2 == 0).count() > 2).count();
}
}
'👨💻 Coding Test > Java' 카테고리의 다른 글
[Programmers/Java/Lv.0] 46.팩토리얼 (0) | 2024.12.05 |
---|---|
[Programmers/Java/Lv.0] 45.최댓값 만들기(1) (0) | 2024.12.04 |
[Programmers/Java/Lv.0] 43.주사위의 개수 (0) | 2024.12.02 |
[Programmers/Java/Lv.0] 42.배열 회전시키기 (0) | 2024.12.02 |
[SW Expert Academy/Java/D3] 1221.GNS (0) | 2024.11.15 |