일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 재귀 함수
- NQueen
- 기초
- 동적 계획
- 이진 탐색
- 백준
- 알고리즘
- 순차 탐색
- format 메서드
- MiniHeap
- 배열
- 그리디
- 자료구조
- git hub
- 우분투
- 정렬
- IT
- 트리
- UNIX
- 파이썬
- 분할 정복
- type 함수
- 자기개발
- 문법
- 그래프
- Git
- 탐색
- sys.stdin.readline()
- 스택
- 유닉스
Archives
- Today
- Total
코딩고치
[파이썬][자료구조] Queue 본문
큐 (Queue)
운영체제, 네트워크에서 많이 쓰인다.
큐 구조
- 가장 먼저 데이터를 가장 먼저 꺼낼 수 있는 구조이다.
- FIFO (First-In, First-Out) 방식으로 스택과 꺼내는 순서가 반대이다.
데이터를 출력하면 가장 먼저 넣었던 데이터가 출력이 되고 그 데이터는 queue에서 제거가 된다.
용어
- Enqueue : 큐에 데이터 넣는다.
- Dequeue : 큐에서 데이터를 꺼낸다.
파이썬 queue 라이브러리 활용
일반적인 queue (FIFO (First-In, First-Out))
# queue 라이브러리 이용
import queue
item_queue = queue.Queue()
#데이터 넣기
item_queue.put("Estus Flask")
item_queue.put("Ashen Estus Flask")
#size 확인
item_queue.qsize()
2
#데이터 꺼내기. 인자 없음
item_queue.get()
'Estus Flask'
맨 먼저 넣은 데이터가 먼저 출력된다.
item_queue.qsize()
1
데이터 출력 후 사이즈가 줄어든다.
item_queue.get()
'Ashen Estus Flask'
LifoQueue (LIFO (Last-In, First-Out))
import queue
item_queue = queue.LifoQueue()
#data 넣기
item_queue.put("Estus Flask")
item_queue.put("Ashen Estus Flask")
item_queue.qsize()
2
item_queue.get()
'Ashen Estus Flask'
가장 마지막에 넣은 데이터 먼저 출력된다.
PriorityQueue()
우선순위에 따라서 출력하도록 하는 구조로 자료구조, 알고리즘에서 많이 쓴다.
import queue
item_queue = queue.PriorityQueue()
#튜플을 이용하여 (우선순위, 데이터) 형식으로 넣음
item_queue.put((3, "Estus Flask"))
item_queue.put((2, "Ashen Estus Flask"))
item_queue.put((5, "Estus Shard"))
item_queue.qsize()
3
item_queue.get()
(2, 'Ashen Estus Flask')
숫자가 가장 낮은 것이 우선순위 높다.
item_queue.get()
(3, 'Estus Flask')
item_queue.get()
(5, 'Estus Shard')
Queue가 많이 쓰이는 곳
- 멀티 태스킹을 위한 프로세스 스케쥴링 구현 (운영체제)
특별히 장단점이 없다.
'파이썬 > 자료구조' 카테고리의 다른 글
[파이썬][자료구조] 시간 복잡도 (0) | 2020.04.16 |
---|---|
[파이썬][자료구조] 링크드 리스트 (Linked List) (0) | 2020.04.15 |
[파이썬][자료구조] 스택 (Stack) (0) | 2020.04.15 |
[파이썬][자료구조] 배열 (0) | 2020.04.12 |
[파이썬][자료구조] 자료구조와 알고리즘 (0) | 2020.04.12 |
Comments