양의 정수 n
이 매개변수로 주어질 때, n
이 홀수라면 n
이하의 홀수인 모든 양의 정수의 합을 return 하고 n
이 짝수라면 n
이하의 짝수인 모든 양의 정수의 제곱의 합을 return 하는 solution 함수를 작성해 주세요.
n
≤ 100n | result |
---|---|
7 | 16 |
10 | 220 |
입출력 예 #1
n
은 7로 홀수입니다. 7 이하의 모든 양의 홀수는 1, 3, 5, 7이고 이들의 합인 1 + 3 + 5 + 7 = 16을 return 합니다.입출력 예 #2
n
은 10으로 짝수입니다. 10 이하의 모든 양의 짝수는 2, 4, 6, 8, 10이고 이들의 제곱의 합인 22 + 42 + 62 + 82 + 102 = 4 + 16 + 36 + 64 + 100 = 220을 return 합니다.function solution(n) {
let answer = 0;
if (n%2 == 0){
for(i=0;i<=n;i++){
if(i%2 == 0) answer+=i*i;
}
}else{
for(i=0;i<=n;i++){
if(i%2 !== 0) answer+=i;
}
}
return answer;
}
깔끔하지 못하다 ㅜ
다른풀이
if(n%2===1)
return (n+1)/2*((n + 1)/2) ;
else
return n*(n+1)*(n+2)/6;
const array = Array(n).fill().map((x,idx)=> idx+1);
return n%2 === 0 ? array.reduce((a,b) => b%2===0 ? a+Math.pow(b,2) : a, 0) : array.reduce((a,b) => b%2===0 ? a : a+b, 0);
const isEven = n % 2 === 0;
const arr = Array.from({ length: n }, (_, i) => i + 1);
const filter = arr.filter(n => {
return isEven ? n % 2 === 0 : n % 2 === 1;
})
return isEven ?
filter.reduce((acc, curr) => acc + curr * curr, 0): filter.reduce((acc, curr) => acc + curr, 0);
const isOdd = n % 2 === 1;
return new Array(Math.ceil(n / 2))
.fill(undefined)
.reduce((acc, _, i) => acc + (isOdd ? 2 * i + 1 : (2 * (i + 1)) ** 2), 0);