[프로그래머스] 숨어있는 숫자의 덧셈 (1)
카테고리 : 컴퓨터 공학
태그: programmers · Code Refactoring · 참고 할 만한 다른 사람의 코드 · 코딩 기초 트레이닝 · 프로그래머스 · 코딩테스트 연습 · JavaScript · 숨어있는 숫자의 덧셈 (1) · js 숨어있는 숫자의 덧셈 (1)
태그: programmers · Code Refactoring · 참고 할 만한 다른 사람의 코드 · 코딩 기초 트레이닝 · 프로그래머스 · 코딩테스트 연습 · JavaScript · 숨어있는 숫자의 덧셈 (1) · js 숨어있는 숫자의 덧셈 (1)
문제 설명
문자열 my_string
이 매개변수로 주어집니다. my_string
안의 모든 자연수들의 합을 return하도록 solution 함수를 완성해주세요.
제한사항
- 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합니다.
나의 풀이
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로 간편하게 푸는 방법