Yeon's Frame
  • Intro
  • Project
    • 미소웨더
      • 기획 - 아이디어 및 유스케이스 정리
      • DB 설계 - JPA 활용 중심
  • Study
    • Spring
      • Spring Feature
      • N+1
      • OSIV
      • @Valid
      • Spring Boot Feature
      • Spring 5 Feature
      • JPA vs MyBatis
      • Filter, Interceptor
      • Persistence Context
      • @Transactional
      • @Controlleradvice, @ExceptionHandler
      • Spring Security
      • Dispatcher Servlet
      • @EnableWebMvc
      • Stereo Type
      • AOP
      • JPA Repository
    • Infrastructure
      • Git
      • DNS
      • JWT
      • DevOps
      • Docker
      • Jenkins
      • Cloud Computing
      • MSA
    • Clean Code
      • 깨끗한 코드
      • 의미있는 이름
      • 함수
      • 주석
      • 형식 맞추기
      • 객체와 자료구조
      • 오류 처리
      • 경계
      • 단위테스트
      • 클래스
      • 시스템
  • Basic
    • Java
      • OOP
      • OOL Features
      • Class & Objects
      • Instance & Heap Memory
      • Constructor
      • Reference Type Uses
      • Access Modifier & Hiding
      • This
      • Collaboration
      • Static
      • Inheritance
      • Polimorphism & Casting
      • Abstract Class
      • Interface
      • Object Class
    • Java Coding
      • JVM
      • String, StringBuffer, StringBuilder
      • SOF
      • Blockcing/NonBlocking
      • Enum
      • Static
      • Thread
      • hashCode() | equals()
      • JDK8
      • Stream
      • Optional
      • Lambda & Closure
      • Exception
      • Garbage Collecter
      • Collection
      • Call by Value & Call by Reference
      • Generic
    • Java_Advance
      • Inner Class
      • Lambda Expression
      • Functional Interface
      • OOP vs Lambda Expression
      • Stream
      • Reduce()
      • Exception Handling
      • Custom Exception
      • Error Log
      • IO Stream
      • IO Stream - Serialization
      • File Class
      • Decorator Pattern
      • Thread
    • Data Structure
      • Intro
      • Generic(1)
      • Generic(2) T extends
      • Generic(3) Method
      • Collection Frameworks
      • List
      • Iterator
      • Set
      • Comparable & Comparator
      • Map
  • Practice
    • Algorithm
      • Strategy
        • Primitive, Reference, Generic
        • Number Data Types
        • For-Each
        • Array, Queue, ArrayDeque
        • Array vs ArrayList
Powered by GitBook
On this page
  • Stack
  • Queue
  • contains, remove 등 O(N) API 사용 주의
  • ArrayDeque as Stack
  • ArrayDeque as Queue
  1. Practice
  2. Algorithm
  3. Strategy

Array, Queue, ArrayDeque

Stack

Stack<Integer> stack = new Stack<>();
stack.push(10);
stack.push(20);
System.out.println(stack.peek());
System.out.println(stack.pop());
  • Stack에서 넣는 값은 push()

  • Stack에서 빼서 보는 것은 peek()

  • Stack에서 빼는 것은 pop()

  • FILO

Queue

Queue<Integer> queue = new Queue<>();
queue.add(10);
queue.add(20);
System.out.println(queue.peek());
System.out.println(queue.poll()); // queue는 poll로 빼낸다. FIFO
  • Stack에서 넣는 값은 add()

  • Stack에서 빼서 보는 것은 peek()

  • Stack에서 빼는 것은 poll()

  • FIFO

contains, remove 등 O(N) API 사용 주의

for (int i = 0; i < MAX; i++){
    if (stack.contains(MAX)) {
    }
}
for (int i = 0; i < MAX; i++){
    if (queue.remove(MAX)) {
    }
}
  • contains(), remove() 할 때마다 완전탐색

  • Stack, Queue, ArraydEque, ArrayList 등의 자료구조에서 contains(), remove() 가급적 사용 X

  • MAX = 100000 일 때

    • Stack: 7.016초

    • Queue: 8.48초

  • HashMap의 containsKey는 일반적으로 O(1) 이라 괜찮다.

    • MAX = 100000 일 때: 0.011초

ArrayDeque as Stack

ArrayDeque<Integer> arrayDequeStack = new ArrayDeque<>();
arrayDequeStack.addLast(10);
arrayDequeStack.addLast(20);
System.out.println(arrayDequeStack.peekLast());
System.out.println(arrayDequeStack.pollLast());
  • Stack 이 ArrayDeque보다 미세하게 빠르다 (SingleThread에서)

ArrayDeque as Queue

ArrayDeque<Integer> arrayDequeQueue = new ArrayDeque<>();
arrayDequeQueue.addLast(10);
arrayDequeQueue.addLast(20);
System.out.println(arrayDequeQueue.peekFirst());
System.out.println(arrayDequeQueue.pollFirst());
PreviousFor-EachNextArray vs ArrayList

Last updated 2 years ago