Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- java
- 재귀와반복문
- Spring MVC 동작원리
- 백준
- MySQL
- Spring Web MVC
- 백준 11659
- 투포인터알고리즘
- 알고리즘
- 11659
- 싱글톤패턴
- 코드스테이츠
- 버블정렬
- 재귀함수
- List.of
- vm인스턴스생성
- 코딩테스트
- 프로그래머스
- Array.asList
- 코드스테이츠 백엔드
- GCP
- 클라우드에서 도커 실행하기
- OOP
- 자바
- 스택
- String.valueOf()
- 인텔리제이
- 구간합구하기
- 성능테스트툴
- Spring MVC 구성요소
Archives
- Today
- Total
순간을 기록으로
[JAVA] 후위식 연산 본문
유형
후위식 연산은 대표적인 스택 문제이니 꼭 한번 풀어보자.
풀이
/*
* Integer를 담을 스택을 선언
* 문자열을 문자 하나하나씩 접근한다.
* 만약 문자가 숫자형 문자이면
* 스택에 넣는다.
* 만약 문자가 연산자라면
* 스택에서 상단 숫자 2개를 꺼낸다.
* 2개의 숫자를 연산자로 계산한다.
* 계산한 결과를 스택에 다시 넣는다.
*
* 마지막 스택에 남아있는 숫자를 출력한다.
* */
코드
import java.util.Scanner;
import java.util.Stack;
/*
* Integer를 담을 스택을 선언
* 문자열을 문자 하나하나씩 접근한다.
* 만약 문자가 숫자형 문자이면
* 스택에 넣는다.
* 만약 문자가 연산자라면
* 스택에서 상단 숫자 2개를 꺼낸다.
* 2개의 숫자를 연산자로 계산한다.
* 계산한 결과를 스택에 다시 넣는다.
*
* 마지막 스택에 남아있는 숫자를 출력한다.
* */
public class Main {
public int solution(String str) {
Stack<Integer> stack = new Stack<>();
int a, b, result;
for (char ch : str.toCharArray()) { // 문자열에서 한 문자씩 접근
if (ch >= '0' && ch <= '9') // 문자가 숫자형 문자이면
stack.push(ch - '0');
else { // 문자가 연산자라면
b = stack.pop(); // 연산자 뒤 문자
a = stack.pop(); // 연산자 앞 문자
switch (ch) {
case '+':
stack.push(a+b);
break;
case '-':
stack.push(a-b);
break;
case '*':
stack.push(a*b);
break;
case '/':
stack.push(a/b);
break;
}
}
}
result = stack.peek();
return result;
}
public static void main(String[] args) {
Main T = new Main();
Scanner in = new Scanner(System.in);
String str = in.next();
System.out.println(T.solution(str));
}
}
느낀 점
문자가 숫자형 문자인지 판단할 때
Character.isDigit(ch)을 사용해도 되고 ch >= '0' && ch <= '9'를 이용해도 된다.
'Problem Solving' 카테고리의 다른 글
[JAVA] 피보나치 수열 (0) | 2022.01.10 |
---|---|
[JAVA] Least Recently Used, LRU 문제풀이 (0) | 2022.01.10 |
[JAVA] 슬라이딩 윈도우를 이용한 최대 매출 (0) | 2022.01.09 |
[JAVA] 재귀로 구현하는 팩토리얼 (0) | 2022.01.07 |
[JAVA] 삽입정렬(Inserting Sort) (0) | 2022.01.07 |
Comments