gpt4 book ai didi

Python链表删除功能不起作用

转载 作者:太空宇宙 更新时间:2023-11-04 02:42:42 25 4
gpt4 key购买 nike

这是我的节点:

class Node(object):
def __init__(self, data, next = None):
self.data = data
self.next_node = next
def get_next(self):
return self.next_node
def set_next(self, next):
self.next_node = next
def get_data(self):
return self.data
def set_data(self):
self.data = data

这是 LinkedList 本身:

class LinkedList(object):
def __init__(self, root = None):
self.root = root
self.size = 0
def size(self):
return self.size
def insert(self, data):
new_node = Node (data, self.root)
self.root = new_node
self.size += 1
def delete(self, data):
this_node = self.root
prev_node = None
while this_node:
if this_node.get_data() == data:
if prev_node:
prev_node.set_next(this_node.get_next())
else:
self.root = this_node
self.size -= 1
return True
else:
prev_node = this_node
this_node = this_node.get_next()
return False
def search(self, data):
this_node = self.root
while this_node:
if this_node.get_data() == data:
return data
else:
self.root = this_node.get_next()
return None
def printLL(self):
this_node = self.root
while this_node:
print(this_node.data)
this_node = this_node.get_next()

最后,这些是我正在执行的测试:

ll = LinkedList()
ll.insert(1)
ll.insert(2)
ll.printLL()
ll.delete(2)
ll.printLL()
if ll.search(2):
print("Value 2 found")
else:
print("Value 2 not found")
if ll.search(1):
print("Value 1 found")
else:
print("Value 1 not found")
ll.insert(4)
ll.printLL()
print(str(ll.size()))

编辑:好的,我已经编辑了代码,它不再循环,但是,我现在得到这个输出:

2
1
2
1
Value 2 found
Value 1 not found
4
1
Traceback (most recent call last):
File "C:\Users\ErikIngvoldsen\Documents\Python Code\TestCode.py", line 71, in <module>
print(str(ll.size()))
TypeError: 'int' object is not callable

为什么对象不可调用?另外,为什么我的删除功能不起作用?作为引用,我的输出应该是这样的:

2 1
1
Value 2 not found
Value 1 found
4 1
2

还有格式问题,但现在我只专注于让它正常工作。

最佳答案

问题是在你的循环中你使用了条件 while this_node 而你永远不会改变 this_node 的值。

您应该将 this_node 分配给下一个节点的值,直到您的 LinkedList 结束,您的 printLL() 函数应该是:

def printLL(self):
this_node = self.root
while this_node:
print(this_node.data)
this_node = this_node.get_next()

关于Python链表删除功能不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46028335/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com