홀짝에 따라 다른 값 반환하기

도비김·2024년 2월 22일
0
문제 설명

양의 정수 n이 매개변수로 주어질 때, n이 홀수라면 n 이하의 홀수인 모든 양의 정수의 합을 return 하고 n이 짝수라면 n 이하의 짝수인 모든 양의 정수의 제곱의 합을 return 하는 solution 함수를 작성해 주세요.


제한사항
  • 1 ≤ n ≤ 100

입출력 예
n result
7 16
10 220

입출력 예 설명

입출력 예 #1

  • 예제 1번의 n은 7로 홀수입니다. 7 이하의 모든 양의 홀수는 1, 3, 5, 7이고 이들의 합인 1 + 3 + 5 + 7 = 16을 return 합니다.

입출력 예 #2

  • 예제 2번의 n은 10으로 짝수입니다. 10 이하의 모든 양의 짝수는 2, 4, 6, 8, 10이고 이들의 제곱의 합인 22 + 42 + 62 + 82 + 102 = 4 + 16 + 36 + 64 + 100 = 220을 return 합니다.

solution

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);
profile
To Infinity, and Beyond!

0개의 댓글