숨어있는 숫자의 덧셈 (1)

도비김·2024년 2월 27일
0

Programmers | lv.0 입문

목록 보기
40/101

function solution(my_string) {
return [...my_string].filter(e=>Number.isInteger(+e)).reduce((a,c)=>+a + +c,0);
}

    <h6 class="guide-section-title">문제 설명</h6>
    <div class="markdown solarized-dark"><p>문자열 <code>my_string</code>이 매개변수로 주어집니다. <code>my_string</code>안의 모든 자연수들의 합을 return하도록 solution 함수를 완성해주세요.</p>

제한사항
  • 1 ≤ my_string의 길이 ≤ 1,000
  • my_string은 소문자, 대문자 그리고 한자리 자연수로만 구성되어있습니다.

입출력 예
my_string result
"aAb1B2cC34oOp" 10
"1a2b3c4d123" 16

입출력 예 설명

입출력 예 #1

  • "aAb1B2cC34oOp"안의 한자리 자연수는 1, 2, 3, 4 입니다. 따라서 1 + 2 + 3 + 4 = 10 을 return합니다.

입출력 예 #2

  • "1a2b3c4d123Z"안의 한자리 자연수는 1, 2, 3, 4, 1, 2, 3 입니다. 따라서 1 + 2 + 3 + 4 + 1 + 2 + 3 = 16 을 return합니다.

유의사항
  • 연속된 숫자도 각각 한 자리 숫자로 취급합니다.

solution

function solution(my_string) {
    return [...my_string].filter(e=>Number.isInteger(+e)).reduce((a,c)=>+a + +c,0);
}

다른풀이

function solution(my_string) {
    return [...my_string].reduce((acc,cur)=>Number(cur) ? +acc + +cur : acc, 0)
}

function solution(my_string) {
    return my_string.match(/[0-9]/g).reduce((a,b) => parseInt(a)+parseInt(b));
}
profile
To Infinity, and Beyond!

0개의 댓글