약수의 개수와 덧셈
https://school.programmers.co.kr/learn/courses/30/lessons/77884
📔 문제 설명
두 정수 left와 right가 매개변수로 주어집니다. left부터 right까지의 모든 수들 중에서, 약수의 개수가 짝수인 수는 더하고, 약수의 개수가 홀수인 수는 뺀 수를 return 하도록 solution 함수를 완성해주세요.
💡 입출력 예
absolutes | signs | result |
---|---|---|
[4,7,12] | [true,false,true] | 9 |
[1,2,3] | [false,false,true] | 0 |
💻내가 작성한 코드
- left부터 right까지 반복되도록 반복문작성
- 나머지가 0되는 약수 찾기 (i % j === 0)
- 나머지가 0이 되는 약수 배열에 담기
- 배열의 길이가 짝수면 더하고, 홀수면 빼기
1
2
3
4
5
6
7
8
9
10
11
12
13
14
function solution(left, right) {
var answer = 0;
for (let i = left; i <= right; i++) {
let arr = [];
for (let j = 0; j <= i; j++) {
if (i % j === 0) {
arr.push(j);
}
}
arr.length % 2 === 0 ? (answer += i) : (answer -= i);
}
return answer;
}
💻다른 사람 코드
- if (Number.isInteger(Math.sqrt(i))) {}
- Math.squrt() 사용해서 제곱근 구하기
- Number.isInteger() 통해 제곱근의 정수 판별하기
- ★★ 제곱근이 정수라면 약수는 홀수 ★★
1
2
3
4
5
6
7
8
9
10
11
function solution(left,right){
var answer = 0;
for (let i = left; i <= right; i++) {
if (Number.isInteger(Math.sqrt(i))) {
answer -= i;
} else {
answer += i;
}
}
return answer;
}
This post is licensed under CC BY 4.0 by the author.