백준알고리즘 18282 스택 - java8

Sorbet·2021년 4월 26일
0

코테

목록 보기
25/35
  • 출처 : https://www.acmicpc.net/problem/10828
  • 문제자체는 단순히 스텍자료구조만 사용하는거라 쉬웠지만, 예외처리, BufferedReader랑 StringBuilder 사용하는데 조금 시간이 걸렸다.
  • 앞으로 BufferedReader랑 StringBuilder 클래스와 조금 더 친해지길 바래!
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Stack;


public class Main {

    public static void main(String[] args) throws IOException {

        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        StringBuilder sb = new StringBuilder();
        Stack<Integer> s = new Stack<>();
        String[] ins;

        int n = Integer.parseInt(br.readLine());

        for (int i = 0; i < n; i++) {

            ins = br.readLine().split(" ");

            if (ins[0].equals("push")) {
                s.push(Integer.parseInt(ins[1]));
            } else if (ins[0].equals("pop")) {
                if (s.empty()) {
                    sb.append(-1).append('\n');
                } else {
                    sb.append(s.pop()).append('\n');
                }
            } else if (ins[0].equals("size")) {
                sb.append(s.size()).append('\n');
            } else if (ins[0].equals("empty")) {
                if (s.empty()) {
                    sb.append("1").append('\n');
                } else {
                    sb.append("0").append('\n');
                }

            } else if (ins[0].equals("top")) {
                if (s.empty()) {
                    sb.append("-1").append('\n');
                } else {
                    sb.append(s.peek()).append('\n');
                }
            } else {
                System.out.println("ERROR");
            }

        }
        System.out.println(sb.toString());
        br.close();
        return;

    }

}
profile
Sorbet is good...!

0개의 댓글