Competition/Baekjoon

[백준] 10866번 자바 덱 기초

bisi 2020. 3. 12. 09:42
문제 출처 

https://www.acmicpc.net/problem/10866

 

10866번: 덱

첫째 줄에 주어지는 명령의 수 N (1 ≤ N ≤ 10,000)이 주어진다. 둘째 줄부터 N개의 줄에는 명령이 하나씩 주어진다. 주어지는 정수는 1보다 크거나 같고, 100,000보다 작거나 같다. 문제에 나와있지 않은 명령이 주어지는 경우는 없다.

www.acmicpc.net

 

 

 

접근 방식 및 풀이

- 자바 deque에 대한 기초 문제이다.

- 명령어에 맞춰서 deque 메소드를 호출하고 출력한다.

 

 

 

소스 코드 

import java.util.ArrayDeque;
import java.util.Deque;
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        Deque<Integer> deque = new ArrayDeque<Integer>();
        for (int i = 0; i <n ; i++) {
            String str = sc.next();
            if(str.equals("push_front")){
                deque.addFirst(sc.nextInt());
            }else if(str.equals("push_back")){
                deque.addLast(sc.nextInt());
            }else if(str.equals("pop_front")){
                if(deque.size()<1){
                    System.out.println(-1);
                }else {
                    System.out.println(deque.pollFirst());
                }
            }else if(str.equals("pop_back")){
                if(deque.size()<1){
                    System.out.println(-1);
                }else {
                    System.out.println(deque.pollLast());
                }
            }else if(str.equals("size")){
                System.out.println(deque.size());
            }else if(str.equals("empty")){
                if(deque.isEmpty()){
                    System.out.println(1);
                }else {
                    System.out.println(0);
                }
            }else if(str.equals("front")){
                if(deque.size()<1){
                    System.out.println(-1);
                }else {
                    System.out.println(deque.peekFirst());
                }
            }else if(str.equals("back")){
                if(deque.size()<1){
                    System.out.println(-1);
                }else {
                    System.out.println(deque.peekLast());
                }

            }
        }

    }

}

 

 

 

 

결과 

 

'Competition > Baekjoon' 카테고리의 다른 글

[백준] 10824번 자바  (0) 2020.03.12
[백준] 10845번 자바 큐 기초  (0) 2020.03.12
[백준] 10828번 자바 스택 기초  (0) 2020.03.11