뉴히의 개발 로그
프로그래머스 - 약수의 개수와 덧셈 javascript 본문
문제설명
두 정수 left와 right가 매개변수로 주어집니다. left부터 right까지의 모든 수들 중에서, 약수의 개수가 짝수인 수는 더하고, 약수의 개수가 홀수인 수는 뺀 수를 return 하도록 solution 함수를 완성해주세요.
풀이
function solution(left, right) {
var answer = 0;
for(let i=left; i<=right; i++ ){
let count = 0;
for(let j=1; j<=i; j++ ){
if(i%j === 0) count+=1;
}
if(count % 2 === 0) answer+=i
else answer-=i
}
return answer;
}
다른 사람 풀이
function solution(left, right) {
var answer = 0;
for (let i = left; i <= right; i++){
if(Number.isInteger(Math.sqrt(i)) === true){
answer -= i
}else{
answer += i
}
}
return answer;
}
제곱근이 정수면, 약수의 갯수가 홀수니 빼주고 이외의 상황은 모두 약수가 짝수니까 더해주는 방법
실행 속도도 훨씬 빠르다
'Algorithm' 카테고리의 다른 글
프로그래머스 - 세 개의 구분자 (1) | 2024.05.01 |
---|---|
프로그래머스 Js - 간단한 식 계산하기, Lv.0 (0) | 2024.01.10 |
프로그래머스 JS - 특별한 이차원 배열 1, Lv.0 (1) | 2024.01.09 |
프로그래머스 - 문자열 앞에 0 떼기 (1) | 2023.11.28 |
[TIL] 알고리즘 - 백준 프로그래머스: Lv0 숨어있는 숫자의 덧셈 (1) (0) | 2023.09.22 |