728x90
반응형
✅ 링크드 리스트 (Linked List) 구조
- 연결 리스트라고도 부른다.
- 배열을 순차적으로 연결된 공간에 데이터를 나열하는 데이터 구조이다.
- 링크드 리스트는 떨어진 곳에 존재하는 데이터를 화살표로 연결하여 관리한다.
📌 링크드 리스트의 기본 구조와 용어
- 노드(Node) : 링크드 리스트의 데이터 저장 단위로 (데이터값, 포인터)로 구성된다.
- 포인터(Pointer) : 각 노드 안에서, 다음이나 이전의 노드와의 연결 정보를 가지고 있는 공간이다.
📌 링크드 리스트의 장단점
- 장점
- 미리 데이터 공간을 할당하지 않아도 된다.
- 배열의 경우 미리 데이터 공간을 할당해야 한다.
- 미리 데이터 공간을 할당하지 않아도 된다.
- 단점
- 연결을 위한 별도 데이터 공간이 필요하므로 저장공간 효율이 높지 않다.
- 연결 정보를 찾는 시간이 필요하므로 접근 속도가 느리다.
- 중간 데이터 삭제시, 앞뒤 데이터의 연결을 재구성해야 하는 부가적인 작업 필요하다.
📌 단순연결리스트 구현
class Node:
def __init__(self, data, next=None):
self.data = data
self.next = next
class llManage:
def __init__(self, data):
self.head = Node(data)
def add(self, data) :
if self.head == "" :
self.head = Node(data)
else :
node = self.head
while node.next:
node = node.next
node.next = Node(data)
def delete(self, data) :
if self.head == "" :
print("해당 값을 가진 노드가 없습니다.")
return
if self.head.data == data:
temp = self.head
self.head = self.head.next
del temp
else :
node = self.head
while node.next :
if node.next.data == data :
temp = node.next
node.next = node.next.next
del temp
return
else :
node = node.next
def desc(self) :
node = self.head
while node :
print(node.data)
node = node.next
728x90
반응형
'Studying > Algorithm & Data Structure' 카테고리의 다른 글
[자료구조] 스택(Stack) (0) | 2023.05.24 |
---|---|
[자료구조] 큐 (Queue) (0) | 2023.05.23 |