- Today
- Total
Recent Posts
Recent Comments
Archives
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 파이썬활용
- 중간시험
- 파이썬 강좌
- 기말시험
- 알고리즘
- python 중간고사
- 코딩문제
- 파이썬
- python data structure
- 코딩시험
- 파이썬 입문
- 프로그래밍
- 자료구조
- 알고리즘 강의
- gdrive
- 채용문제
- 파이썬 알고리즘
- 쉬운 파이썬
- 대학시험
- 크롤링
- 파이썬 자료구조
- Crawling
- 파이썬3
- selenium
- 알고리즘 강좌
- c언어
- 자료구조 강의
- 셀레니움
- 파이썬 강의
- 면접 파이썬
Notice
반원 블로그
02b. 단일 연결 리스트(singly linked list) - iv. 삭제 본문
삭제
먼저 삭제되는 데이터에 대한 처리를 얘기하려합니다. C언어의 경우 메모리의 할당 및 해제를 직접 코드에 적어줘야합니다.(malloc과 free) 즉, 관리에서 벗어날 데이터는 할당되었던 메모리를 해제하는 것까지 신경써야됩니다.
하지만 JAVA나 Python은 관리에서 벗어난 데이터의 경우 알아서 처리해주는 가비지 컬렉션(Garbage Collection) 개념을 사용합니다. 그래서 우리는 삭제된 데이터의 메모리 해제는 신경쓰지않고, 관리 체계에 대해서만 생각하면 됩니다.
저장된 노드가 없을 때
당연히 중지시켜야됩니다.
#단일 링크드 리스트
class SLinkedList:
#S_L_list에서 쓸 노드
class Node:
def __init__(self, v, n = None):
self.value = v #저장된 데이터
self.next = n #다음 노드 가리키는 변수
#S_L_List에서 필요한 변수
def __init__(self):
self.head = None #첫 생성시 내부에는 노드가 없으므로
#삽입
def insertNode(self, v): #추가할 데이터
#만일 처음 노드일 경우 -> head값이 None임
if self.head is None :
#head에 새 노드를 저장
self.head = self.Node(v)
else: #이미 노드가 있는 경우
# head에 새 노드를 저장
# 기존 head에 저장된 노드는 새로 생성할 노드의 next로 저장
self.head = self.Node(v,self.head)
def printNode(self):
#데이터가 없을 때
if self.head is None:
print("저장된 데이터가 없음")
return
else:
print("<현재 리스트 구조>", end='\t') #end로 print 마지막 개행을 변경할 수 있습니다.
link = self.head #처음은 head를 지정. 이후부터는 현 노드의 next를 지정
#link가 가리키는 노드가 없을 때까지 반복
#None,0,""는 조건판단에서 False 처리, 그 외는 True로 처리된다.
while link :
print(link.value, '->' , end = ' ')
link = link.next #link를 현 위치 노드의 next로 변경
print() #줄바꿈 용
#삭제
def deleteNode(self):
#노드가 없으면 skip
if self.head is None :
print("삭제할 노드가 없습니다.")
return
##테스트
if __name__=="__main__":
sl = SLinkedList()
sl.deleteNode()
저장된 노드가 있을 때
삭제는 head가 가리키고 있는 노드가 삭제된다.(파이썬에서 딱히 메모리 해제를 하지 않으니 삭제라기보단 관리에서 제외시킨다는 개념이 맞겠습니다.)
결과적으로 head에 다음 노드를 가리키도록 변경하면 됩니다.
코드 구현
#단일 링크드 리스트
class SLinkedList:
#S_L_list에서 쓸 노드
class Node:
def __init__(self, v, n = None):
self.value = v #저장된 데이터
self.next = n #다음 노드 가리키는 변수
#S_L_List에서 필요한 변수
def __init__(self):
self.head = None #첫 생성시 내부에는 노드가 없으므로
#삽입
def insertNode(self, v): #추가할 데이터
#만일 처음 노드일 경우 -> head값이 None임
if self.head is None :
#head에 새 노드를 저장
self.head = self.Node(v)
else: #이미 노드가 있는 경우
# head에 새 노드를 저장
# 기존 head에 저장된 노드는 새로 생성할 노드의 next로 저장
self.head = self.Node(v,self.head)
def printNode(self):
#데이터가 없을 때
if self.head is None:
print("저장된 데이터가 없음")
return
else:
print("<현재 리스트 구조>", end='\t') #end로 print 마지막 개행을 변경할 수 있습니다.
link = self.head #처음은 head를 지정. 이후부터는 현 노드의 next를 지정
#link가 가리키는 노드가 없을 때까지 반복
#None,0,""는 조건판단에서 False 처리, 그 외는 True로 처리된다.
while link :
print(link.value, '->' , end = ' ')
link = link.next #link를 현 위치 노드의 next로 변경
print() #줄바꿈 용
#삭제
def deleteNode(self):
#노드가 없으면 skip
if self.head is None :
print("삭제할 노드가 없습니다.")
return
else:
#head를 현 head의 next. 즉, 다음 노드로 변경.
self.head = self.head.next
##테스트
if __name__=="__main__":
sl = SLinkedList()
sl.insertNode('1st')
sl.insertNode('2nd')
sl.insertNode('3rd')
sl.printNode() # 출력
sl.deleteNode()
sl.deleteNode()
sl.printNode() # 출력
sl.deleteNode()
sl.deleteNode()
sl.printNode() # 출력
위키독스 연재 : https://wikidocs.net/book/2868
'2018~ > 파이썬 자료구조 알고리즘' 카테고리의 다른 글
02c. 이중 연결 리스트(doubly linked list) - iii. 출력 (0) | 2019.05.04 |
---|---|
02c. 이중 연결 리스트(doubly linked list) - ii. 삽입 (0) | 2019.05.03 |
02c. 이중 연결 리스트(Doubly linked list) - i. 구조 (0) | 2019.05.02 |
02b. 단일 연결 리스트(singly linked list) - v. 탐색 (0) | 2019.05.01 |
02b. 단일 연결 리스트(singly linked list) - iii. 출력 (0) | 2019.04.29 |
02b. 단일 연결 리스트(singly linked list) - ii. 삽입 (0) | 2019.04.28 |
02b. 단일 연결 리스트(singly linked list) - i. 구조 (0) | 2019.04.27 |
02b. 단일 연결 리스트(singly linked list) (0) | 2019.04.26 |
Comments