[JavaScript] Lv0 - 홀짝에 따라 다른 값 반환하기

Moon·2024년 11월 24일
0
post-thumbnail

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


문제 설명

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


제한사항

  • 1 ≤ n ≤ 100

입출력 예

nresult
716
10220

입출력 예 설명

입출력 예 #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이고 이들의 제곱의 합인 2² + 4² + 6² + 8² + 10² = 4 + 16 + 36 + 64 + 100 = 220을 return 합니다.

function solution(n) {
    if (n % 2 === 1) { // n이 홀수인 경우
        return Array.from({ length: Math.ceil(n / 2) }, (_, i) => 2 * i + 1).reduce((sum, num) => sum + num, 0);
    } else { // n이 짝수인 경우
        return Array.from({ length: n / 2 }, (_, i) => (i + 1) * 2).reduce((sum, num) => sum + num ** 2, 0);
    }
}

console.log(solution(7)); // 16

코드 설명

  1. 홀수일 경우 (n % 2 === 1)
    • Array.from 생성:
      • Math.ceil(n / 2)만큼의 길이를 가진 배열을 생성합니다. 예: n = 7[0, 1, 2, 3].
      • 각 인덱스를 홀수로 변환합니다. (_, i) => 2 * i + 1. 예: [1, 3, 5, 7].
    • reduce로 합 계산:
      • 배열의 모든 요소를 더합니다. 예: 1 + 3 + 5 + 7 = 16.
  2. 짝수일 경우 (n % 2 === 0)
    • Array.from 생성:
      • n / 2만큼의 길이를 가진 배열을 생성합니다. 예: n = 10[0, 1, 2, 3, 4].
      • 각 인덱스를 짝수로 변환합니다. (i + 1) * 2. 예: [2, 4, 6, 8, 10].
    • reduce로 제곱의 합 계산:
      • 배열의 각 요소를 제곱한 뒤 더합니다. 예: 2² + 4² + 6² + 8² + 10² = 220.
  3. 최종 결과 반환:
    • if 조건에 따라 홀수 또는 짝수에 맞는 결과를 반환합니다.
profile
MOON.DEVLOG

0개의 댓글