새소식

Programmers Coding Test/Java

[프로그래머스 120851] Java - 코딩테스트 입문 / 숨어있는 숫자의 덧셈 (1)

  • -

 

 

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

 

 

https://school.programmers.co.kr/learn/courses/30/lessons/120851

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

 

 

1)  문제

문자열 my_string이 매개변수로 주어집니다. my_string안의 모든 자연수들의 합을 return하도록 solution 함수를 완성해주세요.
제한사항
1 ≤ my_string의 길이 ≤ 1,000
my_string은 소문자, 대문자 그리고 한자리 자연수로만 구성되어있습니다.

 

 

 

2)  예시

 

 

Result Table
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합니다.

 

연속된 숫자도 각각 한 자리 숫자로 취급합니다.

 

 

 

3)  풀이

 

 

1. 클래스 선언을 해줍니다

● class Solution {

클래스명은 대문자로 시작해야하고, 정답이라는 의미로 Solution이라는 단어를 사용하였습니다.

 

 

 

 

2. 문자열 my_string을 매개변수로 하는 solution 메소드를 선언합니다.

solution은 정수를 반환하므로 데이터타입을 int로 합니다.

●    public int solution(String my_string) {

 

 

 

 

3. 제한사항을 확인하고, 만족하지 않을 경우 예외처리합니다.

●     if(1 > my_string.length() || my_string.length() > 1000){
            throw new IllegalArgumentException("제한사항을 확인하세요");
        }
        

 

 

 

4. 자연수를 모두 합한 값이 될 변수 answer를 생성하고 초기화해줍니다.

 int answer = 0;

 

 

 

5. for반복문을 이용하여 my_string의 각문자마다 isDigit 메소드를 이용하여 숫자 여부를 확인하고,

숫자일 경우에 getNumericValue 메소드를 이용하여 문자를 정수로 변환하여 answer 값에 더해줍니다.

모든 순회를 마치면 문자열 내 모든 자연수를 더한 값이 되므로, answer를 반환해줍니다.

  for(int i=0; i < my_string.length(); i++){
            char c = my_string.charAt(i);
            if(Character.isDigit(c)){
                answer = answer + Character.getNumericValue(c);
            }
        }
        return answer;
    }
}

 

 

 

 

 

 

 

 

4)  코드

 

class Solution {
    public int solution(String my_string) {
        if(1 > my_string.length() || my_string.length() > 1000){
            throw new IllegalArgumentException("제한사항을 확인하세요");
        }

        int answer = 0;
        
        for(int i=0; i < my_string.length(); i++){
            char c = my_string.charAt(i);
            if(Character.isDigit(c)){
                answer = answer + Character.getNumericValue(c);
            }
        }
        return answer;
    }
}

 

 

 

 

 

 

 

5)  느낀점

120850번 문제(문자열 정렬하기 (1))와 매우 유사하여 해당 문제를 푼 이후 이 문제를 맞이했을 때 쉽게 풀 수 있었습니다.

 

 

 

 

 

 

 

 

 

Contents

포스팅 주소를 복사했습니다

이 글이 도움이 되었다면 공감 부탁드립니다.