[프로그래머스] 숨어있는 숫자의 덧셈 (1)


문제 설명

문자열 my_string이 매개변수로 주어집니다. my_string안의 모든 자연수들의 합을 return하도록 solution 함수를 완성해주세요.


제한사항

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

입출력 예

my_stringresult
“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합니다.

나의 풀이

function solution(my_string) {
  var answer = 0;
  var naturalNumber = [...my_string].filter((a) =>
    ["1", "2", "3", "4", "5", "6", "7", "8", "9"].includes(a) ? true : false
  );
  return test.reduce(function (acc, cur) {
    return parseInt(acc) + parseInt(cur);
  });
}

나의 두번째 풀이(Code Refactoring)

function solution(my_string) {
  let result = 0;
  for (i = 0; i <= my_string.length; i++) {
    if (Number(my_string[i])) {
      result += Number(my_string[i]);
    }
  }
  return result;
}

//첫번째 풀이때 엄청 복잡하게 풀었던것 같다
// my_string의 문자열을 반복한 후 Number를 판별한후 result에 합산하여 출력했다

참고 할 만한 다른 사람의 코드

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

//reduce로 간편하게 푸는 방법