Doubly Linked List
생활코딩: Data Structure (자료구조)
참고 사이트 : VISUALGO
소개
- doubly linked list의 핵심은 노드와 노드가 서로 연결되어 있다는 점
- 아래 그림을 보면 linked list와는 다르게 노드가 이전 노드(previous)와 다음 노드(next)로 구성되어 있음
data:image/s3,"s3://crabby-images/f58ab/f58ab586bc3a775f031f068e38428f4f0a8940e8" alt=""
- 이것의 가장 큰 장점은 양방향으로 연결되어 있기 때문에 노드를 탐색하는 방향이 양쪽으로 가능하다는 것
장점
- 양방향 탐색의 가장 큰 장점은 특정 인덱스 위치의 엘리먼트를 가져올 때와 반복자를 이용해서 탐색할 때 드러남
인덱스의 데이터 가져오기
data:image/s3,"s3://crabby-images/f9c28/f9c28cfe5b976e083d8416a0d59f9c971cfe1341" alt=""
- 노드가 6개일 때 3번째 엘리먼트 이전은 처음부터 시작해서 next를 이용해서 탐색하고, 4번째 이후의 엘리먼트는 마지막 노드부터 previous를 이용해서 조회
- 단순 연결 리스트가 최악의 경우 노드 전체를 탐색해야 했던 것에 비해서 양방향 연결 리스트는 탐색해야하는 엘리먼트가 반으로 줄어듬
노드 탐색하기
- 단방향 연결 리스트는 다음 노드의 탐색만 가능했던 것에 비해서 이중 연결 리스트의 경우 앞뒤로 탐색이 가능
- 상황에 따라 탐색의 방향이 바뀌어야 하는 경우라면 이중 연결 리스트를 사용
data:image/s3,"s3://crabby-images/1e945/1e9457b160d2cdf79c7ceda80b2acc54d299eb55" alt=""
단점
- 이전 노드를 지정하기 위한 변수를 하나 더 사용해야 하는데 이는 메모리를 더 많이 사용한다는 의미
- 하지만 장점이 크기 때문에 현실에서 사용하는 연결 리스트는 대부분 이중 연결 리스트
노드의 추가
- 단순 연결 리스트와 거의 비슷
- 중요한 차이점은 양방향으로 연결을 해야 한다는 점
- 새로운 노드(25)를 기존의 노드(20, 30)와 연결하는 방법
data:image/s3,"s3://crabby-images/1e72f/1e72f74df03ae760f287cb5940c58d089898f5b7" alt=""
data:image/s3,"s3://crabby-images/d8f1b/d8f1bfe216a1d2724e5bd70054afa981b3688601" alt=""
data:image/s3,"s3://crabby-images/63484/634841859a8c813f0363168192ac7e86f7ce7d37" alt=""
data:image/s3,"s3://crabby-images/b6352/b635208a8592144e6ad85a3e69a009e2eb28edf9" alt=""
data:image/s3,"s3://crabby-images/87d62/87d62447c309bc498b188bbbb7ccd5022691b889" alt=""
data:image/s3,"s3://crabby-images/7a08b/7a08b61f7045d4a09f4cf0d15c00710cc0ed2073" alt=""
노드의 제거
data:image/s3,"s3://crabby-images/d5a05/d5a0512342419025c652fe3dd944674198d7ee57" alt=""
data:image/s3,"s3://crabby-images/4cbc0/4cbc0dcfeca9aa2da4f34216fcc5785f66ab6fe9" alt=""
data:image/s3,"s3://crabby-images/89a98/89a98e1ae0aaa9b07d263c6e3184d673fb119a68" alt=""
data:image/s3,"s3://crabby-images/c1331/c1331efeea65c5cc7dd13439108368c125134a6a" alt=""
data:image/s3,"s3://crabby-images/e44a6/e44a67ff3ef9331cfa71d75ccdc15a31c4d1e5d1" alt=""
data:image/s3,"s3://crabby-images/6da0e/6da0e9dc4f40a9440343ea6542b0a6e7ca1dc215" alt=""
data:image/s3,"s3://crabby-images/82301/8230126ffdfe33e198f9ccd133816336187a10ee" alt=""