이중 연결 목록
단일 연결 목록
data:image/s3,"s3://crabby-images/4f835/4f83575229eecdfbdab5e43c531c8aed02a57690" alt=""
이중 연결 목록
data:image/s3,"s3://crabby-images/df280/df2803809f0fe39e623a0af7cd4ee9aef5cdd2c1" alt=""
따라서 Singly Linked List에서 노드를 생성할 때 다음과 같은 결과를 얻었습니다.
data:image/s3,"s3://crabby-images/0c588/0c588b33e76160b7661103c908d6e115d4babd53" alt=""
우리는 실제로
data:image/s3,"s3://crabby-images/39ad6/39ad68fc483f5f5ea5a18cc6d0dfc2a31930f6c1" alt=""
수업 시간에 다음과 같이 작성했습니다.
B
data:image/s3,"s3://crabby-images/ef5a2/ef5a2d4dd9cc15c22b495514167e82b07c03cb2d" alt=""
그러나 이중 연결 목록에는 다음이 있습니다.
data:image/s3,"s3://crabby-images/f0841/f084107607e20098995d7c51205f06faca42d84d" alt=""
이제 이중 연결 목록 클래스를 만들 수 있습니다.
data:image/s3,"s3://crabby-images/23ebb/23ebb912cc77248a81b4af19e57fa76e12e9a959" alt=""
클래스를 호출하는 이중 연결 목록을 만듭니다.
data:image/s3,"s3://crabby-images/8850b/8850b31ca417694327141f1cb7eadf1ea893fefa" alt=""
이것은 이중 연결 목록을 만듭니다.
data:image/s3,"s3://crabby-images/a61fe/a61fe00b6c4c94c373f6d01afd1a65110a804f2d" alt=""
전체 코드:
class Node:
def __init__(self, value):
self.value = value
self.next = None
self.prev = None
class DoublyLinkedList:
def __init__(self, value):
new_node = Node(value)
self.head = new_node
self.tail = new_node
self.length = 1
def print_list(self):
temp = self.head
while temp is not None:
print(temp.value)
temp = temp.next
#Creating a doubly Linked List which has a node 7
my_doubly_linked_list = DoublyLinkedList(7)
#Printing the list
my_doubly_linked_list.print_list()
추가
사례 1:
값이 없고 추가할 때
data:image/s3,"s3://crabby-images/f4526/f45261d156c73be2f201d45aa531f2233717dad4" alt=""
그리고 이것을 이것으로
data:image/s3,"s3://crabby-images/fb78b/fb78b0f1864ff65638bc0fd67588ce8682836256" alt=""
먼저 head가 None을 가리키는지 확인합니다.
data:image/s3,"s3://crabby-images/878fa/878fae748dc8b028bcdd70482deccbb4299818b0" alt=""
해낼거야
data:image/s3,"s3://crabby-images/e74e6/e74e619d7bb24ff7548eef0afa8ef3d0824e7d57" alt=""
data:image/s3,"s3://crabby-images/bd14d/bd14d4e763625790cf279790ac949172258435c4" alt=""
사례 2:
data:image/s3,"s3://crabby-images/b820b/b820b78fe4393571a685f8c83d0c469172d2e87f" alt=""
이제 이것을 코딩하여 새 노드를 추가합니다.
data:image/s3,"s3://crabby-images/e9159/e91598ebef79ba1c48baadcbf46385a1eb3e5901" alt=""
data:image/s3,"s3://crabby-images/88b9a/88b9a052d680dbb253132f5fbcc1317171353cac" alt=""
data:image/s3,"s3://crabby-images/179df/179df616e4435d7109180c2a1fc99e3db7df7711" alt=""
따라서 전체 코드는 다음과 같습니다.
data:image/s3,"s3://crabby-images/fe3bc/fe3bc46b89fb51099951a0e32db490cc010a11ac" alt=""
총 코드:
class Node:
def __init__(self, value):
self.value = value
self.next = None
self.prev = None
class DoublyLinkedList:
def __init__(self, value):
new_node = Node(value)
self.head = new_node
self.tail = new_node
self.length = 1
def print_list(self):
temp = self.head
while temp is not None:
print(temp.value)
temp = temp.next
def append(self, value):
new_node = Node(value)
if self.head is None:
self.head = new_node
self.tail = new_node
else:
self.tail.next = new_node
new_node.prev = self.tail
self.tail = new_node
self.length += 1
return True
#A linked list of a node 1
my_doubly_linked_list = DoublyLinkedList(1)
#Appending node 2
my_doubly_linked_list.append(2)
my_doubly_linked_list.print_list()
팝
사례 1:
목록에 0개의 노드가 있는 경우
data:image/s3,"s3://crabby-images/fd194/fd19446755f7672d866eb547c1caf08f5bf3cba1" alt=""
이를 위해 다음이 필요합니다.
우리는 아무것도 반환하지 않기 때문에
data:image/s3,"s3://crabby-images/f8f01/f8f01fc9eeff44ff721d9691c5206a6d1a078341" alt=""
사례 2: 값이 2개 이상인 경우
data:image/s3,"s3://crabby-images/eded6/eded60296f4a3019c5d88127a9ff3d25422ba781" alt=""
먼저 임시 변수를 생성합니다.
data:image/s3,"s3://crabby-images/cdfcb/cdfcb25b06af5bcf40f9e802a8a7d2a3b903b91d" alt=""
그런 다음 꼬리를 이전 노드로 설정합니다.
data:image/s3,"s3://crabby-images/5aa48/5aa4898d84a4b838bb60f1ca849cf937e2fdae5b" alt=""
그런 다음 마지막 항목에서 중단하기 위해 꼬리의 다음 방향을 없음으로 설정합니다.
data:image/s3,"s3://crabby-images/b4b0a/b4b0a8fffed7900bb0a8866f21ac5f4b0bf45a76" alt=""
마지막 노드에 대해 동일:
data:image/s3,"s3://crabby-images/1f37b/1f37befbb95a6fe0afdf112529b983e221a35a48" alt=""
사례 3:
값이 1개일 때:
data:image/s3,"s3://crabby-images/53b4f/53b4f6511c1024d045be1800925f496af4431cd9" alt=""
팝하고 머리와 꼬리도 없음으로 설정합니다.
data:image/s3,"s3://crabby-images/c5fda/c5fda16471685adc68efef69d3ab241b201451e7" alt=""
목록은 다음과 같습니다.
data:image/s3,"s3://crabby-images/d028f/d028f703c321a0122e927c19ad97099f833e400c" alt=""
따라서 코드는 다음과 같습니다.
data:image/s3,"s3://crabby-images/95efa/95efa176aa609b778d7ce9b7b339d6a2770dae91" alt=""
또한 다음 형식으로 변경할 수 있습니다.
data:image/s3,"s3://crabby-images/e3bfe/e3bfea19b2d1ebc8bceaaf8f9c10d9ba3d3c47af" alt=""
총 코드:
class Node:
def __init__(self, value):
self.value = value
self.next = None
self.prev = None
class DoublyLinkedList:
def __init__(self, value):
new_node = Node(value)
self.head = new_node
self.tail = new_node
self.length = 1
def print_list(self):
temp = self.head
while temp is not None:
print(temp.value)
temp = temp.next
def append(self, value):
new_node = Node(value)
if self.head is None:
self.head = new_node
self.tail = new_node
else:
self.tail.next = new_node
new_node.prev = self.tail
self.tail = new_node
self.length += 1
return True
def pop(self):
#For 0 items in list
if self.length == 0:
return None
temp = self.tail
#For 1 items in list
if self.length == 1:
self.head = None
self.tail = None
#For more than 1 nodes in list
else:
self.tail = self.tail.prev
self.tail.next = None
temp.prev = None
self.length -= 1
return temp
#Creates a list of Node 1 & Node 2
my_doubly_linked_list = DoublyLinkedList(1)
my_doubly_linked_list.append(2)
# (2) Items - Returns Node 2
print(my_doubly_linked_list.pop())
# (1) Item - Returns Node 1
print(my_doubly_linked_list.pop())
# (0) Items - Returns None
print(my_doubly_linked_list.pop())
앞에 추가
사례: 1
목록에 아무것도 없을 때
data:image/s3,"s3://crabby-images/7b0d7/7b0d7722655726fe63ec3b984bc41abeeeabaa7d" alt=""
따라서 머리와 꼬리를 설정합니다.
data:image/s3,"s3://crabby-images/6427c/6427ca44c9058cfea4a1d5cc69abca0e3b862ef1" alt=""
사례 2:
값이 1개 이상인 경우:
data:image/s3,"s3://crabby-images/d9a05/d9a051c697d6c607877c36fb3c835761f902116f" alt=""
먼저 다음을 수행합니다.
data:image/s3,"s3://crabby-images/16196/1619614361b3abf5eb481ee5e669e8c049dea01c" alt=""
그 다음에
data:image/s3,"s3://crabby-images/b1359/b1359ac6f454db732f4f5f26fd1bb8d6ad14166f" alt=""
그 다음에
data:image/s3,"s3://crabby-images/087cc/087cc3fc1fcc050c70ef7ef7498e573eef1b879b" alt=""
전체 코드는 다음과 같습니다.
class Node:
def __init__(self, value):
self.value = value
self.next = None
self.prev = None
class DoublyLinkedList:
def __init__(self, value):
new_node = Node(value)
self.head = new_node
self.tail = new_node
self.length = 1
def print_list(self):
temp = self.head
while temp is not None:
print(temp.value)
temp = temp.next
def append(self, value):
new_node = Node(value)
if self.head is None:
self.head = new_node
self.tail = new_node
else:
self.tail.next = new_node
new_node.prev = self.tail
self.tail = new_node
self.length += 1
return True
def pop(self):
if self.length == 0:
return None
temp = self.tail
if self.length == 1:
self.head = None
self.tail = None
else:
self.tail = self.tail.prev
self.tail.next = None
temp.prev = None
self.length -= 1
return temp
def prepend(self, value):
new_node = Node(value)
# If we have no value in the list
if self.length == 0:
self.head = new_node
self.tail = new_node
#If we have more than 1 values
else:
new_node.next = self.head
self.head.prev = new_node
self.head = new_node
self.length += 1
return True
#Doubly list with Node 1 & Node 3
my_doubly_linked_list = DoublyLinkedList(2)
my_doubly_linked_list.append(3)
#Prepending Node 1
my_doubly_linked_list.prepend(1)
my_doubly_linked_list.print_list()
얻다
Singly Linked List의 경우 다음 코드가 적합했습니다.
data:image/s3,"s3://crabby-images/e4146/e4146592458ff354a75afdfe6f6ed65faf492fec" alt=""
data:image/s3,"s3://crabby-images/eeaac/eeaac1276d608a3895cfed9d37c2da46b9ede8a8" alt=""
우리는 이것을 이것으로 바꿀 것입니다
data:image/s3,"s3://crabby-images/e5783/e578383eb93100eabece36bde102aa98e29e359a" alt=""
사례 1:
이중 연결 목록 내에 있는 항목을 반환해 보겠습니다. 인덱스 1을 반환하자
data:image/s3,"s3://crabby-images/610ca/610ca70e77fb6e8864bb267638c042b4e9f53df9" alt=""
인덱스가 상반기인 경우
data:image/s3,"s3://crabby-images/c1b1d/c1b1d7d62c02dcbddab8dbdda40daab91e4e9531" alt=""
하반기라면
S
data:image/s3,"s3://crabby-images/64726/6472619a98775c199b5823bb17ae1c0405e1442a" alt=""
꼬리를 임시로 설정하고 뒤로 반복
data:image/s3,"s3://crabby-images/dc9f3/dc9f380404a28a53a141797c6a1fc74aa840fe23" alt=""
우리가 그것을 얻을 때 온도를 반환
따라서 전체 코드는
class Node:
def __init__(self, value):
self.value = value
self.next = None
self.prev = None
class DoublyLinkedList:
def __init__(self, value):
new_node = Node(value)
self.head = new_node
self.tail = new_node
self.length = 1
def print_list(self):
temp = self.head
while temp is not None:
print(temp.value)
temp = temp.next
def append(self, value):
new_node = Node(value)
if self.head is None:
self.head = new_node
self.tail = new_node
else:
self.tail.next = new_node
new_node.prev = self.tail
self.tail = new_node
self.length += 1
return True
def pop(self):
if self.length == 0:
return None
temp = self.tail
if self.length == 1:
self.head = None
self.tail = None
else:
self.tail = self.tail.prev
self.tail.next = None
temp.prev = None
self.length -= 1
return temp
def prepend(self, value):
new_node = Node(value)
if self.length == 0:
self.head = new_node
self.tail = new_node
else:
new_node.next = self.head
self.head.prev = new_node
self.head = new_node
self.length += 1
return True
def pop_first(self):
if self.length == 0:
return None
temp = self.head
if self.length == 1:
self.head = None
self.tail = None
else:
self.head = self.head.next
self.head.prev = None
temp.next = None
self.length -= 1
return temp
def get(self, index):
if index < 0 or index >= self.length:
return None
temp = self.head
#Checking if the index is in 1st half
if index < self.length/2:
for _ in range(index):
temp = temp.next
#Checking if the index is in 2nd half
else:
temp = self.tail
for _ in range(self.length - 1, index, -1):
temp = temp.prev
return temp #Will return the node . But for value, use temp.value
#Creating a doubly list of 0,5,9,3
my_doubly_linked_list = DoublyLinkedList(0)
my_doubly_linked_list.append(5)
my_doubly_linked_list.append(9)
my_doubly_linked_list.append(3)
#Lokking for index 1 no node
print(my_doubly_linked_list.get(1))
#Looking for index 2 no node
print(my_doubly_linked_list.get(2))
세트
이 인덱스 1 값을 3에서 4로 설정해 봅시다.
data:image/s3,"s3://crabby-images/40c7d/40c7dc1f9613475f18920f6f54ad96b8821e2142" alt=""
data:image/s3,"s3://crabby-images/62c89/62c8936ef08f27b94178e6ca962932deb4860a10" alt=""
그래서 여기서 인덱스가 범위 내에 있는지 확인하고 그렇다면 값을 변경합니다.
data:image/s3,"s3://crabby-images/b1269/b12699e8d3f181bd7fcff9793ef7cfaae123528c" alt=""
그렇지 않으면 False를 반환합니다.
전체 코드는
class Node:
def __init__(self, value):
self.value = value
self.next = None
self.prev = None
class DoublyLinkedList:
def __init__(self, value):
new_node = Node(value)
self.head = new_node
self.tail = new_node
self.length = 1
def print_list(self):
temp = self.head
while temp is not None:
print(temp.value)
temp = temp.next
def append(self, value):
new_node = Node(value)
if self.head is None:
self.head = new_node
self.tail = new_node
else:
self.tail.next = new_node
new_node.prev = self.tail
self.tail = new_node
self.length += 1
return True
def pop(self):
if self.length == 0:
return None
temp = self.tail
if self.length == 1:
self.head = None
self.tail = None
else:
self.tail = self.tail.prev
self.tail.next = None
temp.prev = None
self.length -= 1
return temp
def prepend(self, value):
new_node = Node(value)
if self.length == 0:
self.head = new_node
self.tail = new_node
else:
new_node.next = self.head
self.head.prev = new_node
self.head = new_node
self.length += 1
return True
def pop_first(self):
if self.length == 0:
return None
temp = self.head
if self.length == 1:
self.head = None
self.tail = None
else:
self.head = self.head.next
self.head.prev = None
temp.next = None
self.length -= 1
return temp
def get(self, index):
if index < 0 or index >= self.length:
return None
temp = self.head
if index < self.length/2:
for _ in range(index):
temp = temp.next
else:
temp = self.tail
for _ in range(self.length - 1, index, -1):
temp = temp.prev
return temp
def set_value(self, index, value):
temp = self.get(index)
#if the index is within the range
if temp:
temp.value = value
return True
#if the index is not within range
return False
#Doubly linked list of 11,3,23,7
my_doubly_linked_list = DoublyLinkedList(11)
my_doubly_linked_list.append(3)
my_doubly_linked_list.append(23)
my_doubly_linked_list.append(7)
#setting index value to 4
my_doubly_linked_list.set_value(1,4)
my_doubly_linked_list.print_list()
끼워 넣다
특정 인덱스에서 노드를 삽입할 것입니다.
먼저 인덱스가 범위 내에 있는지 확인합니다.
data:image/s3,"s3://crabby-images/038f0/038f08202d4f0fbb2774bee9868ed436c9ee0d88" alt=""
사례 1:
처음에 추가해야 하는 경우
data:image/s3,"s3://crabby-images/f2b3f/f2b3f9e09549f2f32e9c340c6adfe6a1e48c5ee4" alt=""
사례 2:
목록의 마지막에 추가
data:image/s3,"s3://crabby-images/e0d4f/e0d4fe28cdbe02e03201f69e78df73ad46a6677f" alt=""
사례 3:
중간 어딘가에 추가합니다.
우리가 이것을 만들고 싶다고 가정하십시오.
data:image/s3,"s3://crabby-images/4e471/4e471e3dc7b80dc9958fd22648eb0c0197b3efa7" alt=""
그것에
data:image/s3,"s3://crabby-images/99b4d/99b4d1cd5174eee05ac05d8047f661ca0783450f" alt=""
그래서 1과 2 사이에 노드를 삽입하려고 합니다.
따라서 인덱스 1을 이전으로, 인덱스 2를 이후로 설정합니다.
data:image/s3,"s3://crabby-images/70b0a/70b0ac45ec8f504c567bb7b04df80d39221a4902" alt=""
data:image/s3,"s3://crabby-images/da1d9/da1d961afa5a38fd478cb964c8b7cc2b30e4b4a9" alt=""
우리는 이것을 만들 것입니다
data:image/s3,"s3://crabby-images/c38b6/c38b69aede1d2ae8a9a2f879a0c969479386b9ff" alt=""
이에
data:image/s3,"s3://crabby-images/b1ed6/b1ed662866392068dd4fe8b21a4de0076fb0f63e" alt=""
data:image/s3,"s3://crabby-images/92576/9257694eb85c3e6257c47cc3f9cb3502e385b1fc" alt=""
data:image/s3,"s3://crabby-images/3e233/3e23339ed499b9e6b64cc503ad26961cd80df75b" alt=""
data:image/s3,"s3://crabby-images/ec303/ec3036068a0bbe25d08d77ca40c8cc1ae6fb8a82" alt=""
data:image/s3,"s3://crabby-images/80008/80008c6115baa3a0d580e864924bd1483775b27e" alt=""
따라서 코드는
class Node:
def __init__(self, value):
self.value = value
self.next = None
self.prev = None
class DoublyLinkedList:
def __init__(self, value):
new_node = Node(value)
self.head = new_node
self.tail = new_node
self.length = 1
def print_list(self):
temp = self.head
while temp is not None:
print(temp.value)
temp = temp.next
def append(self, value):
new_node = Node(value)
if self.head is None:
self.head = new_node
self.tail = new_node
else:
self.tail.next = new_node
new_node.prev = self.tail
self.tail = new_node
self.length += 1
return True
def pop(self):
if self.length == 0:
return None
temp = self.tail
if self.length == 1:
self.head = None
self.tail = None
else:
self.tail = self.tail.prev
self.tail.next = None
temp.prev = None
self.length -= 1
return temp
def prepend(self, value):
new_node = Node(value)
if self.length == 0:
self.head = new_node
self.tail = new_node
else:
new_node.next = self.head
self.head.prev = new_node
self.head = new_node
self.length += 1
return True
def pop_first(self):
if self.length == 0:
return None
temp = self.head
if self.length == 1:
self.head = None
self.tail = None
else:
self.head = self.head.next
self.head.prev = None
temp.next = None
self.length -= 1
return temp
def get(self, index):
if index < 0 or index >= self.length:
return None
temp = self.head
if index < self.length/2:
for _ in range(index):
temp = temp.next
else:
temp = self.tail
for _ in range(self.length - 1, index, -1):
temp = temp.prev
return temp
def set_value(self, index, value):
temp = self.get(index)
if temp:
temp.value = value
return True
return False
def insert(self, index, value):
#to check if the index is within range
if index < 0 or index > self.length:
return False
#to add a node at the start
if index == 0:
return self.prepend(value)
#to add a node at the end
if index == self.length:
return self.append(value)
#to add a node within the list
new_node = Node(value)
before = self.get(index - 1)
after = before.next
new_node.prev = before
new_node.next = after
before.next = new_node
after.prev = new_node
self.length += 1
return True
#Doubly linked list of nodes 1 ,3
my_doubly_linked_list = DoublyLinkedList(1)
my_doubly_linked_list.append(3)
#at the index 1, adding node 2
my_doubly_linked_list.insert(1,2)
my_doubly_linked_list.print_list()
제거하다
인덱스가 범위를 벗어났는지 확인
data:image/s3,"s3://crabby-images/0bd9b/0bd9b52d70dae9cdeaba6abe5a7b7e062f69467c" alt=""
사례 1:
첫 번째 항목을 반환합니다.
data:image/s3,"s3://crabby-images/c85f9/c85f9de407d652dfce1269f1d90ae090eb2c913c" alt=""
이것에 이것
data:image/s3,"s3://crabby-images/09668/09668554a0a33b906445d3438faeeba3a8334217" alt=""
이를 위해 우리는 팝
data:image/s3,"s3://crabby-images/7a7dc/7a7dc7a80d12caefcfbedf28598991f7c09d4dc0" alt=""
사례 2:
마지막에서 제거합니다.
data:image/s3,"s3://crabby-images/484c0/484c04c02632acc8941052d4a0c14562a1c8d488" alt=""
사례 3:
중간에서 무언가를 제거하려면
data:image/s3,"s3://crabby-images/7d9f1/7d9f1a022831fcadd79fc618dc2a9695a370a00c" alt=""
예를 들어 인덱스 2 숫자 값을 제거합니다. 첫째, 변수를 가리 킵니다.
data:image/s3,"s3://crabby-images/4f350/4f350cae21150753277600150314ce6d2a067639" alt=""
data:image/s3,"s3://crabby-images/6987a/6987ad9607f0ba3518e396c4af57b4d0fdd5a221" alt=""
다음과 같을 수 있습니다
data:image/s3,"s3://crabby-images/af580/af580a671175ccdf570a8bfec767f25ed7bf79fa" alt=""
data:image/s3,"s3://crabby-images/7537e/7537e04afd1e07979e316cae17b5dc5753afd483" alt=""
data:image/s3,"s3://crabby-images/d0368/d0368ed6d9b6bc0879fd956f510628d8e27562b6" alt=""
data:image/s3,"s3://crabby-images/dfbd5/dfbd5bd11b79baa11f93c2a3c90726b50d3da39c" alt=""
사용
data:image/s3,"s3://crabby-images/73d65/73d65674cfa26f0754677020262972e83ecd4792" alt=""
총 코드는
class Node:
def __init__(self, value):
self.value = value
self.next = None
self.prev = None
class DoublyLinkedList:
def __init__(self, value):
new_node = Node(value)
self.head = new_node
self.tail = new_node
self.length = 1
def print_list(self):
temp = self.head
while temp is not None:
print(temp.value)
temp = temp.next
def append(self, value):
new_node = Node(value)
if self.head is None:
self.head = new_node
self.tail = new_node
else:
self.tail.next = new_node
new_node.prev = self.tail
self.tail = new_node
self.length += 1
return True
def pop(self):
if self.length == 0:
return None
temp = self.tail
if self.length == 1:
self.head = None
self.tail = None
else:
self.tail = self.tail.prev
self.tail.next = None
temp.prev = None
self.length -= 1
return temp
def prepend(self, value):
new_node = Node(value)
if self.length == 0:
self.head = new_node
self.tail = new_node
else:
new_node.next = self.head
self.head.prev = new_node
self.head = new_node
self.length += 1
return True
def pop_first(self):
if self.length == 0:
return None
temp = self.head
if self.length == 1:
self.head = None
self.tail = None
else:
self.head = self.head.next
self.head.prev = None
temp.next = None
self.length -= 1
return temp
def get(self, index):
if index < 0 or index >= self.length:
return None
temp = self.head
if index < self.length/2:
for _ in range(index):
temp = temp.next
else:
temp = self.tail
for _ in range(self.length - 1, index, -1):
temp = temp.prev
return temp
def set_value(self, index, value):
temp = self.get(index)
if temp:
temp.value = value
return True
return False
def insert(self, index, value):
if index < 0 or index > self.length:
return False
if index == 0:
return self.prepend(value)
if index == self.length:
return self.append(value)
new_node = Node(value)
before = self.get(index - 1)
after = before.next
new_node.prev = before
new_node.next = after
before.next = new_node
after.prev = new_node
self.length += 1
return True
def remove(self, index):
#Checking the range
if index < 0 or index >= self.length:
return None
#to remove from the beginning
if index == 0:
return self.pop_first()
#to remove from the last
if index == self.length - 1:
return self.pop()
#to remove from the middle of the doubly linked list
temp = self.get(index)
temp.next.prev = temp.prev
temp.prev.next = temp.next
temp.next = None
temp.prev = None
self.length -= 1
return temp
# a doubly linked list of 0,1 & 2 nodes
my_doubly_linked_list = DoublyLinkedList(0)
my_doubly_linked_list.append(1)
my_doubly_linked_list.append(2)
# removing index 1 out of the list
print(my_doubly_linked_list.remove(1), '\n')
my_doubly_linked_list.print_list()
완료!
data:image/s3,"s3://crabby-images/d024c/d024cd4058691acd83f6586a11d8a0de991fab11" alt=""
Reference
이 문제에 관하여(이중 연결 목록), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://dev.to/mitul3737/doubly-linked-list-igo텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)