https://school.programmers.co.kr/learn/courses/30/lessons/120902
정답
class Solution {
public int solution(String my_string) {
String arr[] = my_string.split(" "); //공백으로 구분
int answer = Integer.parseInt(arr[0]);
for(int i=0; i<arr.length; i++)
{
if(arr[i].equals("+"))
{
answer+=Integer.parseInt(arr[i+1]);
}
else if(arr[i].equals("-"))
{
answer-=Integer.parseInt(arr[i+1]);
}
}
return answer;
}
}
다른 사람의 풀이
import java.util.*;
class Solution {
public int solution(String my_string) {
int answer = 0;
StringTokenizer st = new StringTokenizer(my_string);
int length = st.countTokens();
Stack<Integer> stack = new Stack<Integer>();
while(st.hasMoreTokens()){
String str = st.nextToken();
if(stack.isEmpty()) {
stack.push(Integer.parseInt(str));
continue;
}
if(str.equals("+")){
stack.push(stack.pop()+Integer.parseInt(st.nextToken()));
}else if(str.equals("-")){
stack.push(stack.pop()-Integer.parseInt(st.nextToken()));
}
}
answer = stack.pop();
return answer;
}
}
'Java > 프로그래머스' 카테고리의 다른 글
[JAVA] 프로그래머스 - 숫자 찾기 (0) | 2024.05.06 |
---|---|
[JAVA] 프로그래머스 - 배열의 유사도 (0) | 2024.05.05 |
[JAVA] 프로그래머스 - 가장 큰 수 찾기 (0) | 2024.05.05 |
[JAVA] 프로그래머스 - 편지 (0) | 2024.05.05 |
[JAVA] 프로그래머스 - 한 번만 등장한 문자 (0) | 2024.05.02 |