Contents

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

   Feb 16, 2024     1 min read

“숨어있는 숫자의 덧셈 1” 문제에 대하여 알아본 글입니다.

코딩 테스트 문제를 풀며, 풀었던 문제에 대한 회고와 다른 풀이 방법을 알아보며, 알아가고자 합니다.

문제에 대해 먼저 알아보겠습니다.

문제

문자열 my_string이 매개변수로 주어집니다.

my_string안의 모든 자연수들의 합을 return하도록 solution 함수를 완성해주세요.

제한사항

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

입출력 예시

my_stringresult
“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까지의 숫자만 추출하여 더한다. 만약 - 다른 숫자 범위가 필요한 경우 코드를 수정해야 한다.