Algorithm/Programmers_Java
[Java] 숨어있는 숫자의 덧셈 (1)
guswn100059
2023. 3. 29. 22:17
문제 설명
문자열 my_string이 매개변수로 주어집니다. my_string안의 모든 자연수들의 합을 return하도록 solution 함수를 완성해주세요.
제한사항
- 1 ≤ my_string의 길이 ≤ 1,000
- my_string은 소문자, 대문자 그리고 한자리 자연수로만 구성되어있습니다.
입출력 예my_stringresult
"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합니다.
유의사항
- 연속된 숫자도 각각 한 자리 숫자로 취급합니다.
내 코드)
class Solution {
public int solution(String my_string) {
String[] str = my_string.split("");
int a = 0;
int b = 0;
int c = 0;
int d = 0;
int e = 0;
int f = 0;
int g = 0;
int h = 0;
int j = 0;
for(int i = 0; i < my_string.length(); i++) {
if(str[i].equals("1")) a += 1;
if(str[i].equals("2")) b += 2;
if(str[i].equals("3")) c += 3;
if(str[i].equals("4")) d += 4;
if(str[i].equals("5")) e += 5;
if(str[i].equals("6")) f += 6;
if(str[i].equals("7")) g += 7;
if(str[i].equals("8")) h += 8;
if(str[i].equals("9")) j += 9;
}
int result = a+b+c+d+e+f+g+h+j;
return result;
}
}
replaceAll() 함수 사용)
class Solution {
public int solution(String my_string) {
int answer = 0;
String str = my_string.replaceAll("[^0-9]", "");
for(char i : str.toCharArray()) {
answer += Character.getNumericValue(i);
}
return answer;
}
}