将二进制树转换为双链接列表-Python-错误消息
请帮助我解决leetcode问题 contract搜索树到分类的双链接列表:
将二进制搜索树转换为到位的圆形双关联列表。
您可以将左右指针视为在双连接列表中的前身和后继指针的代名词。对于圆形双链接列表,第一个元素的前身是最后一个元素,最后一个元素的后继是第一个元素。
我正在尝试解决它 - 我不以最佳方式知道 - 但我至少想获得有效的答案。在我看来,列表已对其进行排序,并且是双重链接的,并且指针指向正确的值,但我无法获得正确的解决方案。
我遇到了错误:
链接列表[1,2,3,4,5]不是有效的圆形双链接列表。
以下是我的代码
class Node:
def __init__(self, val, left=None, right=None):
self.val = val
self.left = left
self.right = right
def inOrderTraversal(node, array):
if node == None:
return
inOrderTraversal(node.left, array)
array.append(node.val)
inOrderTraversal(node.right, array)
return array
class Solution:
def treeToDoublyList(self, root: 'Optional[Node]') -> 'Optional[Node]':
if root is None:
return None
array = []
inOrderTraversal(root, array)
head = Node(array[0])
head.left = Node(array[-1])
prev_node = head
for i in range(1, len(array)):
num = array[i]
node = Node(num)
prev_node.right = node
node.left = prev_node
prev_node = node
if i == len(array) - 1:
node.right = head
count = 0
node = head
while count < 5:
print("new Test")
print(node)
print(node.left.val)
print(node.right.val)
node = node.right
count += 1
# print(head.right.val)
return head
打印输出是:
new Test
<__main__.Node object at 0x7f0318a062c0>
5
2
new Test
<__main__.Node object at 0x7f0318a06a40>
1
3
new Test
<__main__.Node object at 0x7f0318a06c20>
2
4
new Test
<__main__.Node object at 0x7f0318a3e680>
3
5
new Test
<__main__.Node object at 0x7f0318a3e6e0>
4
1
我添加了此输出,以确保双链接列表很好,但是测试框架表示不是。
当我将BST作为1、2、3、4、5作为值的输入时,生成的双链接列表在哪里错误?
Please help me with the LeetCode problem Convert binary search tree to sorted doubly linked list:
Convert a Binary Search Tree to a sorted Circular Doubly-Linked List in place.
You can think of the left and right pointers as synonymous to the predecessor and successor pointers in a doubly-linked list. For a circular doubly linked list, the predecessor of the first element is the last element, and the successor of the last element is the first element.
I am trying to solve it - I know not in the optimal way - but I would like to at least get a valid answer. Although it looks to me that the list is sorted and it is doubly linked and that the pointers point to the correct values, I cannot get the correct solution.
I am getting the error:
The linked list [1,2,3,4,5] is not a valid circular doubly linked list.
Below is my code
class Node:
def __init__(self, val, left=None, right=None):
self.val = val
self.left = left
self.right = right
def inOrderTraversal(node, array):
if node == None:
return
inOrderTraversal(node.left, array)
array.append(node.val)
inOrderTraversal(node.right, array)
return array
class Solution:
def treeToDoublyList(self, root: 'Optional[Node]') -> 'Optional[Node]':
if root is None:
return None
array = []
inOrderTraversal(root, array)
head = Node(array[0])
head.left = Node(array[-1])
prev_node = head
for i in range(1, len(array)):
num = array[i]
node = Node(num)
prev_node.right = node
node.left = prev_node
prev_node = node
if i == len(array) - 1:
node.right = head
count = 0
node = head
while count < 5:
print("new Test")
print(node)
print(node.left.val)
print(node.right.val)
node = node.right
count += 1
# print(head.right.val)
return head
Printed output is:
new Test
<__main__.Node object at 0x7f0318a062c0>
5
2
new Test
<__main__.Node object at 0x7f0318a06a40>
1
3
new Test
<__main__.Node object at 0x7f0318a06c20>
2
4
new Test
<__main__.Node object at 0x7f0318a3e680>
3
5
new Test
<__main__.Node object at 0x7f0318a3e6e0>
4
1
I added this output so to make sure that the doubly linked list is fine, but the test framework says it is not.
Where is the generated doubly linked list wrong, when I give a BST as input that has 1, 2, 3, 4, 5 as values?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
问题是
head.left
是分配的节点
实例,它不是在循环的最后一次迭代中创建的节点。因此,您有两个尾部节点。看到某事物的另一种方法是计算您调用node()
的次数:这是一次太多。然后,当您向前浏览列表时,一切都可以,但是当您从
head
向后走到上一个节点时,该节点的left
属性仍然是无
。解决方案是从您的代码中删除这一行:
以及这些行中的这些行 - 它们并没有错,但是在之后进行操作是更自然的, 已经完成:
现在在循环之后,执行此操作(
node
是列表中的 last 节点):一些改进的想法
turn
inordertraversal
进入发电机。利用
节点
构造函数通过其参数设置
left
属性的功能The problem is that
head.left
is assigned aNode
instance that is not the node that will be created in the last iteration of the loop. So you have two tail nodes. Another way to see something is wrong, is to count the number of times you callNode()
: it is one time too many.When you then walk forward through the list, all will be OK, but when you walk backward from the
head
to the previous node, that node'sleft
attribute will still beNone
.The solution is to remove this line from your code:
And also these lines from the loop -- they are not wrong, but it is more natural to just do that action after the loop has finished:
And now after the loop, do this (when
node
is the last node in the list):Some ideas for improvement
Turn
inOrderTraversal
into a generator.Make use of the
Node
constructor's capability to set aleft
attribute via its argument