[프로그래머스] 이어 붙인 수

백승연·2024년 1월 5일
0

프로그래머스 - Lv. 0

목록 보기
48/60
post-thumbnail

🗒️ 문제

정수가 담긴 리스트 num_list가 주어집니다. num_list의 홀수만 순서대로 이어 붙인 수와 짝수만 순서대로 이어 붙인 수의 합을 return하도록 solution 함수를 완성해주세요.


제한 사항

  • 2 ≤ num_list의 길이 ≤ 10
  • 1 ≤ num_list의 원소 ≤ 9
  • num_list에는 적어도 한 개씩의 짝수와 홀수가 있습니다

입출력 예

num_listresult
[3, 4, 5, 2, 1]393
[5, 7, 8, 3]581

입출력 예 설명

입출력 예 #1

  • 홀수만 이어 붙인 수는 351이고 짝수만 이어 붙인 수는 42입니다. 두 수의 합은 393입니다.

입출력 예 #2

  • 홀수만 이어 붙인 수는 573이고 짝수만 이어 붙인 수는 8입니다. 두 수의 합은 581입니다.

🖋️ 나의 풀이

function solution(num_list) {
    let odd = [];
    let even = [];

    for (let i = 0; i < num_list.length; i++) {
        if (num_list[i] % 2 == 1) {
            odd += num_list[i];
        } else {
            even += num_list[i];
        }
    }
    return Number(odd) + Number(even);
}

💡 다른 사람들의 풀이

# 1

function solution(num_list) {
    const { odds, evens } = num_list.reduce(({ odds, evens }, num) => {
        if (num % 2 === 0) {
            evens.push(num)
        } else {
            odds.push(num)
        }
        return { odds, evens }
    }, { odds: [], evens: [] })
    return Number(odds.join('')) + Number(evens.join(''))
}

# 2

function solution(num_list) {
    var even = num_list.filter(n => n % 2 === 0).reduce((acc, cur) => acc+cur, '');
    var odd = num_list.filter(n => n % 2 === 1).reduce((acc, cur) => acc+cur, '');
    return Number(even) + Number(odd);
}



📝 모르는 내용 찾아보기

profile
공부하는 벨로그

0개의 댓글