문제 설명
문자열 my_string이 매개변수로 주어집니다. my_string안의 모든 자연수들의 합을 return하도록 solution 함수를 완성해주세요.
제한사항
- 1 ≤ my_string의 길이 ≤ 1,000
- my_string은 소문자, 대문자 그리고 한자리 자연수로만 구성되어있습니다.
입출력 예
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합니다.
유의사항
연속된 숫자도 각각 한 자리 숫자로 취급합니다.
풀이 1
class Solution {
public int solution(String my_string) {
int answer = 0;
String[] arr = my_string.replaceAll("[^0-9]", "").split(""); // or [a-zA-Z]
for (int i=0; i<arr.length; i++) {
answer += Integer.parseInt(arr[i]);
}
return answer;
}
}
// String클래스 replaceAll(), split() Integer클래스 parseInt();
풀이 2
class Solution {
public int solution(String my_string) {
int answer = 0;
int i = 0;
my_string = my_string.replaceAll("[^0-9]","");
while(i < my_string.length()) {
answer += Integer.parseInt(String.valueOf(my_string.charAt(i)));
i++;
}
return answer;
}
}
// valueOf() 사용
풀이 2
class Solution {
public int solution(String myString) {
return myString.chars().mapToObj(i -> (char) i).filter(Character::isDigit).map(String::valueOf).mapToInt(Integer::valueOf).sum();
}
}
// 람다사용
'👨💻 Coding Test > Programers' 카테고리의 다른 글
[Programmers/Java/Lv.0/문자열 유형] 51.컨트롤 제트 (0) | 2025.02.22 |
---|---|
[Programmers/Java/Lv.0/수학 유형] 50.소인수분해 (1) | 2025.02.18 |
[Programmers/Java/Lv.0/문자열 유형] 48.문자열 정렬하기 (1) (1) | 2025.02.11 |
[Programmers/Java/Lv.0/문자열 유형] 47.모음제거 (0) | 2025.02.10 |
[Programmers/Java/Lv.0] 46.팩토리얼 (0) | 2024.12.05 |