숨어있는 숫자의 덧셈 1 (with.Java)
“숨어있는 숫자의 덧셈 1” 문제에 대하여 알아본 글입니다.
코딩 테스트 문제를 풀며, 풀었던 문제에 대한 회고와 다른 풀이 방법을 알아보며, 알아가고자 합니다.
문제에 대해 먼저 알아보겠습니다.
문제
문자열 my_string이 매개변수로 주어집니다.
my_string안의 모든 자연수들의 합을 return하도록 solution 함수를 완성해주세요.
제한사항
- 1 ≤ my_string의 길이 ≤ 1,000
- my_string은 소문자, 대문자 그리고 한자리 자연수로만 구성되어있습니다.
입출력 예시
my_string | result |
---|---|
“aAb1B2cC34oOp” | 10 |
“1a2b3c4d123” | 16 |
문제에 대한 나의 풀이
class Solution {
public int solution(String my_string) {
int answer = 0;
for (char ch : my_string.toCharArray()) {
if (Character.isDigit(ch)) {
answer += Character.getNumericValue(ch);
}
}
return answer;
}
}
풀이 설명
- solution(String my_string): 주어진 문자열 my_string에서 숫자를 추출하고, 추출한 숫자들을 더한 결과를 반환한다.
- int answer: 최종 결과를 저장할 변수.
- 문자열을 순회하면서 Character.isDigit(ch)를 사용하여 각 문자가 숫자인지 확인하고, 숫자라면 Character.getNumericValue(ch)를 사용하여 해당 숫자를 누적하여 더한다.
- 최종적으로 더해진 값을 반환한다.
코드 장점
- 숫자 합산이 간편: 각 문자에서 숫자를 추출하여 더하는 과정이 간편하고 직관적이다.
코드 단점
- 숫자 범위 제한: 코드는 문자열에서 0부터 9까지의 숫자만 추출하여 더한다. 만약 - 다른 숫자 범위가 필요한 경우 코드를 수정해야 한다.