728x90
<코딩 테스트>
약수의 개수가 세 개 이상인 수를 합성수라고 합니다. 자연수 n이 매개변수로 주어질 때 n이하의 합성수의 개수를 return하도록 solution 함수를 완성해주세요.
<나의 풀이 과정>
우선 해당 문제를 풀 때
✔1 : 소수도 합성수도 아닌 1
✔소수: 약수의 개수가 2개인 자연수, 1과 자기 자신만을 약수로 갖는 자연수
✔합성수: 약수의 개수가 3개 이상인 자연수 (1보다 큰 자연수 중 소수가 아닌 자연수)
※약수가 1과 자기 자신만 있는 자연수를 소수라고 하는 점
이때 n으로 들어온 정수의 약수 개수를 구하는 메소드를 하나 구하고,
약수의 개수가 2가 아니거나, n이 1이 아니면 answer +1
왜냐하면 1은 필요 없고 약수가 2개가 아닌 경우는 약수가 3개이기 때문입니다.
<나의 풀이 코드>
class Solution {
public int div(int n) {
int count = 0;
for (int i = 1; i <= n; i++) {
if (n % i == 0)
count++;
}
return count;
}
public int solution(int n) {
int answer = 0;
for (int i = 1; i <= n; i++) {
if (div(i) != 2 && div(i) != 1)
answer++;
}
return answer;
}
}
<다른사람 풀이 1>
class Solution {
public int solution(int n) {
int answer = 0;
for (int i = 1; i <= n; i++) {
int cnt = 0;
for (int j = 1; j <= i; j++) {
if (i % j == 0) cnt++;
}
if (cnt >= 3) answer++;
}
return answer;
}
}
<다른사람 풀이 2>
class Solution {
public int solution(int n) {
int answer = 0;
for (int i = 4; i <= n; i++) {
for (int j = 2; j <= i; j++) {
if (i % j == 0 && j != i) {
answer++;
break;
}
}
}
return answer;
}
}
728x90
'주니어 기초 코딩공부 > JAVA_programmers_코딩테스트' 카테고리의 다른 글
모스 부호 (1)_programmers_lev00 (1) | 2022.12.09 |
---|---|
중복된 문자 제거_programmers_lev00 (0) | 2022.12.09 |
369게임_programmers_lev00 (0) | 2022.12.08 |
문자열 정렬하기 (2)_programmers_lev00 (2) | 2022.12.08 |
인덱스 바꾸기_programmers_lev00 (0) | 2022.12.08 |