숨어있는 숫자의 덧셈 (1)
https://school.programmers.co.kr/learn/courses/30/lessons/120851
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))와 매우 유사하여 해당 문제를 푼 이후 이 문제를 맞이했을 때 쉽게 풀 수 있었습니다.