저장을 습관화

프로그래머스 LV.0 홀수 vs 짝수 본문

코딩 테스트/프로그래머스 - 자바스크립트

프로그래머스 LV.0 홀수 vs 짝수

ctrs 2023. 9. 16. 22:52

프로그래머스 LV.0 홀수 vs 짝수

https://school.programmers.co.kr/learn/courses/30/lessons/181887

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

1. 문제 명

홀수 vs 짝수


2. 문제 설명

정수 리스트 num_list가 주어집니다. 가장 첫 번째 원소를 1번 원소라고 할 때, 홀수 번째 원소들의 합과 짝수 번째 원소들의 합 중 큰 값을 return 하도록 solution 함수를 완성해주세요. 두 값이 같을 경우 그 값을 return합니다.


3. 제한 사항

- 5 ≤ num_list의 길이 ≤ 50

- -9 ≤ num_list의 원소 ≤ 9


4. 예시

num_list result
[4, 2, 6, 1, 7, 6] 17
[-1, 2, 5, 6, 3] 8


5. 기본 제공 코드

function solution(num_list) {
    var answer = 0;
    return answer;
}


6. 제출한 내 답

const solution = (n_str) => {
  let odd = n_str
    .filter((v, i) => {
      if (i % 2 === 0) return v;
    })
    .reduce((a, b) => a + b, 0);

  let even = n_str
    .filter((v, i) => {
      if (i % 2 === 1) return v;
    })
    .reduce((a, b) => a + b, 0);

  return odd > even ? odd : even;
};

 

6-2. VSC에 작성한 내용

const solution = (n_str) => {
  let odd = n_str
    .filter((v, i) => {
      if (i % 2 === 0) return v;
    })
    .reduce((a, b) => a + b, 0);

  let even = n_str
    .filter((v, i) => {
      if (i % 2 === 1) return v;
    })
    .reduce((a, b) => a + b, 0);

  return odd > even ? odd : even;
};

// 테스트
console.log(solution([4, 2, 6, 1, 7, 6]));
console.log(solution([-1, 2, 5, 6, 3]));


7. 특이사항

없음


8. 다른 사람이 작성한 답

8-1. map

function solution(num_list) {
    let even = 0;
    let odd = 0

    num_list.map((v, idx) => {
        !(idx % 2) ? even += v : odd += v; 
    })

    return odd > even ? odd : even; 
}

map을 사용해서 각 요소와 인덱스를 사용하되, 이로 인해 새로 만들어질 배열은 사용하지 않는다...