이번에는 연결리스트의 마지막 포스팅을 하도록 하겠습니다!!
연결 리스트가 힘을 발휘할 때
연결 리스트를 조금 더 빠르게 사용하기 위한 새로운 메서드
class LinkedList:
def __init__(self):
self.nodeCount = 0
self.head = Node(None) # 비어있는 dummy node 추가
self.tail = None
self.head.next = self.tail
연산 정의
def insertAfter(self, prev, newNode):
def insertAfter(self, prev, newNode):
newNode.next = prev.next
prev.next = newNode
self.nodeCount += 1
return True
코드 구현 시 주의사항
def insertAfter(self, prev, newNode):
newNode.next = prev.next
if prev.next is None:
self.tail = newNode
prev.next = newNode
self.nodeCount += 1
return True
insertAt의 구현
def insertAt(self, pos, newNode):
def popAfter(self, prev):
코드 구현 시 주의사항
(1) prev가 마지막 node 일 때, (prev.next == None)
class Node:
def __init__(self, item):
self.data = item
self.next = None
class LinkedList:
def __init__(self):
self.nodeCount = 0
self.head = Node(None)
self.tail = None
self.head.next = self.tail
def __repr__(self):
if self.nodeCount == 0:
return 'LinkedList: empty'
s = ''
curr = self.head
while curr.next:
curr = curr.next
s += repr(curr.data)
if curr.next is not None:
s += ' -> '
return s
def getLength(self):
return self.nodeCount
def traverse(self):
result = []
curr = self.head
while curr.next:
curr = curr.next
result.append(curr.data)
return result
def getAt(self, pos):
if pos < 0 or pos > self.nodeCount:
return None
i = 0
curr = self.head
while i < pos:
curr = curr.next
i += 1
return curr
def insertAfter(self, prev, newNode):
newNode.next = prev.next
if prev.next is None:
self.tail = newNode
prev.next = newNode
self.nodeCount += 1
return True
def insertAt(self, pos, newNode):
if pos < 1 or pos > self.nodeCount + 1:
return False
if pos != 1 and pos == self.nodeCount + 1:
prev = self.tail
else:
prev = self.getAt(pos - 1)
return self.insertAfter(prev, newNode)
def concat(self, L):
self.tail.next = L.head.next
if L.tail:
self.tail = L.tail
self.nodeCount += L.nodeCount