티스토리 뷰
프로그래머스 알고리즘 고득점 kit - 스택/큐
1. python의 리스트 특성
- 리스트는 동적 배열(Daynamic Array)로 구현되어 있다.
- 리스트의 요소는 메모리 상에서 연속적으로 저장된다
- pop(0)을 호출하면 첫번째 요소를 제거 후 이후 나머지 모든 요소를 한 칸씩 앞으로 이동시켜야 한다
→ pop(0)의 시간 복잡도는 O(n)이다(리스트의 길이에 비례)
2. Deque의 특성
- Deque(Double-Ended Queue)는 양방향으로 데이터를 효율적으로 추가 및 제거할 수 있도록 설계된 자료구조이다.
- python의 collections.deque는 이중 연결 리스트로 구현되어 있다.
- popleft()를 호출하면 첫번째 노드 제거 후 포인터를 업데이트 한다
→ 다른 요소를 이동시키는 작업이 없으므로 O(1)의 시간복잡도를 가진다
3. 문제 풀이 비교
(1) pop(0)로 풀기 성능 : 메모리: 10.2 MB, 시간: 267.21 ms
def solution(bridge_length, weight, truck_weights):
time = 0
temp_w = 0
bridge = [0] * bridge_length
while truck_weights or temp_w:
time += 1
truck =bridge.pop(0)
temp_w -= truck
if truck_weights and (temp_w + truck_weights[0] <= weight):
truck = truck_weights.pop(0)
bridge.append(truck)
temp_w += truck
else:
bridge.append(0)
return time
(2) dequeue로 풀기 성능: 메모리: 10.1 MB, 시간: 53.60 ms
from collections import deque
def solution(bridge_length, weight, truck_weights):
time = 0
bridge = deque([0] * bridge_length) # 다리 길이만큼 초기화
temp_w = 0 # 현재 다리 위 트럭 무게 합계
while truck_weights or temp_w > 0: # 대기 트럭이 있거나 다리 위에 트럭이 있는 동안 반복
time += 1
# 다리에서 트럭(또는 빈 공간) 제거
temp_w -= bridge.popleft()
if truck_weights and temp_w + truck_weights[0] <= weight:
# 새로운 트럭 추가
truck = truck_weights.pop(0)
bridge.append(truck)
temp_w += truck
else:
# 트럭이 못 올라오면 빈 공간 추가
bridge.append(0)
return time
반응형
'AI > Python' 카테고리의 다른 글
[python] 우선순위 큐(Priority Queue)와 힙(Heap) (1) | 2024.12.27 |
---|---|
[python] 스택을 이용한 주식가격 문제풀이 (1) | 2024.12.26 |
[python] any, index, pop, 내장 Error (1) | 2024.12.24 |
[python] 내장함수(input, dir), 외장함수(global, os, time, datetime) (0) | 2024.12.23 |
[python] 스택, 큐 (0) | 2024.12.23 |
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- Python
- 스크랩
- 오픽
- 줄넘기
- 빅데이터 분석기사
- 아침
- SQL
- llm
- 30분
- 프로그래머스
- IH
- 영어회화
- ChatGPT
- 갓생
- 운동
- 뉴스
- 루틴
- 티스토리챌린지
- 경제
- 아침운동
- 다이어트
- opic
- C언어
- 기초
- 고득점 Kit
- 미라클모닝
- 오블완
- 실기
- 습관
- Ai
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함