두 정수 left와 right가 매개변수로 주어집니다. left부터 right까지의 모든 수들 중에서, 약수의 개수가 짝수인 수는 더하고, 약수의 개수가 홀수인 수는 뺀 수를 return 하도록 solution 함수를 완성해주세요.
function solution(left, right) {
let arr = [];
for(let i = left; i < right+1; i++){
arr.push(i)
}
return arr.reduce((acc, cur)=>{
if(Math.sqrt(cur) === Math.floor(Math.sqrt(cur))){
return acc - cur;
}
return acc + cur;
},0)
}
right + 1 안하고 왜 안되지 갸웃거리다가 로그 찍어보고 바로 풀었다.
new Array.fill로도 어떻게 할 수 있었을거 같은데 한번 궁리해봐야겠다.
출처: 프로그래머스 코딩 테스트 연습, https://programmers.co.kr/learn/challenges#