Contents

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

   May 7, 2024     1 min read

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

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

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

문제

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

my_string은 소문자, 대문자, 자연수로만 구성되어있습니다.

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

제한사항

  • 1 ≤ my_string의 길이 ≤ 1,000
  • 1 ≤ my_string 안의 자연수 ≤ 1000
  • 연속된 수는 하나의 숫자로 간주합니다.
  • 000123과 같이 0이 선행하는 경우는 없습니다.
  • 문자열에 자연수가 없는 경우 0을 return 해주세요.

입출력 예시

my_stringresult
“aAb1B2cC34oOp”37
“1a2b3c4d123Z”133

문제에 대한 나의 풀이

class Solution {
    public int solution(String my_string) {
        int answer = 0;
        String[] strArr = my_string.replaceAll("[a-zA-Z]", " ").split(" ");

        for(String str : strArr){
            if(!str.equals("")){
                answer += Integer.valueOf(str);
            }
        }
        return answer;
    }
}

풀이 설명

  • 알파벳 치환 및 문자열 분리: 주어진 문자열에서 알파벳을 공백으로 치환하고, 그 결과를 공백을 기준으로 분리하여 문자열 배열로 만듭니다.
  • 숫자 추출 및 합산: 문자열 배열을 순회하면서 각 요소를 숫자로 변환하고, 변환된 숫자를 합산합니다. 빈 문자열은 무시합니다.
  • 결과 반환: 합산된 결과를 반환합니다.

코드 장단점

  • 장점: 정규식을 사용하여 알파벳을 공백으로 치환하고 문자열을 쉽게 분리했습니다. 코드가 간결하고 이해하기 쉽게 작성되었습니다.
  • 단점: 이 코드는 입력이 주어진 형식에 맞는다고 가정합니다. 잘못된 형식의 입력이 주어지면 예외 처리가 필요합니다. 문자열을 분리하고 합산하는 과정에서 추가적인 문자열 배열을 생성하여 메모리를 더 사용합니다.