
오류에 대한 지적이나 질문, 토의 환영합니다. 자유롭게 댓글 남겨주세요!.!

| 배열 | 연결리스트 | |
|---|---|---|
| 저장공간 | 연속한 위치 | 임의의 위치 |
| 특정 원소 지칭 | 매우 간편 | 선형탐색과 유사 |
| 시간 복잡도 |
class Node:
def __init__(self, item):
self.data = item
self.next = None
class LinkedList:
def __init__(self):
self.nodeCount = 0
self.head = None
self.tail = None
def getAt(self, pos):
if pos < 1 or pos > self.nodeCount:
return None
i = 1
curr = self.head
while i < pos:
curr = curr.next
i += 1
return curr
def traverse(self):
answer = []
curr = self.head
while curr is not None:
answer.append(curr.data)
curr = curr.next
return answer
def getLength(self):
return self.nodeCount
def insertAt(self, pos, newNode):
if pos < 1 or pos > self.nodeCount + 1:
return False
if pos == 1:
newNode.next = self.head
self.head = newNode
else:
if pos == self.nodeCount + 1:
prev = self.tail
else:
prev = self.getAt(pos - 1)
newNode.next = prev.next
prev.next = newNode
if pos == self.nodeCount + 1:
self.tail = newNode
self.nodeCount += 1
return True
| 맨 앞에 삽입하는 경우 | |
| 중간에 삽입하는 경우 | |
| 맨 끝에 삽입하는 경우 |
def popAt(self, pos):
if pos < 1 or self.nodeCount < pos:
raise IndexError
if pos == 1:
res = self.head.data
if self.nodeCount == 1:
self.head = None
self.tail = None
else:
self.head = self.head.next
else:
prev = self.getAt(pos - 1)
curr = prev.next
res = curr.data
if pos == self.nodeCount:
prev.next = None
self.tail = prev
else:
prev.next = curr.next
self.nodeCount -= 1
return res
| 맨 앞에 삭제하는 경우 | |
| 중간에 삭제하는 경우 | |
| 맨 끝에 삭제하는 경우 |
def concat(self, L):
self.tail.next = L.head
if L.tail:
self.tail = L.tail
self.nodeCount += L.nodeCount

이 글은 프로그래머스 스쿨 인공지능 데브코스 과정에서 공부한 내용을 바탕으로 정리한 글입니다.