홀짝에 따라 다른 값 반환하기
문제 설명
양의 정수 n이 매개변수로 주어질 때, n이 홀수라면 n 이하의 홀수인 모든 양의 정수의 합을 return 하고 n이 짝수라면 n 이하의 짝수인 모든 양의 정수의 제곱의 합을 return 하는 solution 함수를 작성해 주세요.
입출력 예
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 합니다.
나의 풀이
function solution(n) {
let array = Array(n).fill(0).map((v, i) => i + 1);
let answer = array.reduce((acc, cur, index) => {
if ( n % 2 === 0 && (index + 1) % 2 === 0) acc += cur ** 2
if ( n % 2 !== 0 && (index + 1) % 2 !== 0) acc += cur
return acc;
}, 0)
return answer;
}
reduce 메서드를 이용해서 n이 홀수인지 짝수인지에 따라 acc에 cur을 다르게 더해주도록 했다.
다른 사람의 풀이
function solution(n) {
var answer = 0;
if(n%2==0){
for(let i=1; i<=n; i++){
if(i%2==0){
answer += i*i;
}
}
}
else{
for(let i=1; i<=n; i++){
if(i%2==1){
answer += i;
}
}
}
return answer;
}
reduce 말고 for문과 if문을 적용한 풀이!
'알고리즘 > Programmers' 카테고리의 다른 글
[TIL] 2023.06.03 Programmers_배열 조각하기 (0) | 2023.06.03 |
---|---|
[TIL] 2023.06.02 Programmers_배열 만들기 3 (0) | 2023.06.02 |
[TIL] 2023.05.30 Programmers_문자열 겹쳐쓰기 (0) | 2023.05.30 |
[TIL] 2023.05.30 Programmers_리스트 자르기 (0) | 2023.05.30 |
[TIL] 2023.05.26 Programmers_세로 읽기 (0) | 2023.05.27 |
댓글