Faerie255 2022-11-03 17:46 采纳率: 62.5%
浏览 17
已结题

Python单链表 不知道如何修改

img


第22行提示'Node ' object has no attribute 'next'
万分感谢

  • 写回答

1条回答 默认 最新

  • JarodYv 人工智能领域新星创作者 2022-11-03 18:27
    关注

    我觉得你的DeleteElementInTail写的不对。我帮你重写了一下,运行没有问题。

    代码如下,如果对你有帮助,望采纳

    class Node:
        def __init__(self, data):
            self.data = data
            self.next = None
    
    
    class SingleLinkedList:
        def __init__(self):
            self.head = Node(None)
    
        def IsEmpty(self):
            if self.head.next is None:
                print("当前单列表为空")
    
        def InsertElementIn(self, n):
            n.next = self.head.next
            self.head.next = n
    
        def VisitElement(self, n):
            if n:
                print(n.data, '->', end='')
    
        def TraverseElement(self):
            cNode = self.head
            while cNode:
                cNode = cNode.next
                self.VisitElement(cNode)
    
        def DeleteElementInTail(self):
            cNode = self.head
            while True:
                if cNode.next.next is None:
                    break
                cNode = cNode.next
            del cNode.next
            cNode.next = None
    
    
    if __name__ == "__main__":
        lst = SingleLinkedList()
        lst.IsEmpty()
        lst.InsertElementIn(Node(1))
        lst.InsertElementIn(Node(2))
        lst.InsertElementIn(Node(3))
        lst.TraverseElement()
        print()
        lst.DeleteElementInTail()
        lst.TraverseElement()
        print()
        lst.DeleteElementInTail()
        lst.TraverseElement()
    
    
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 11月20日
  • 已采纳回答 11月12日
  • 创建了问题 11月3日

悬赏问题

  • ¥15 seatunnel 怎么配置Elasticsearch
  • ¥15 PSCAD安装问题 ERROR: Visual Studio 2013, 2015, 2017 or 2019 is not found in the system.
  • ¥15 (标签-MATLAB|关键词-多址)
  • ¥15 关于#MATLAB#的问题,如何解决?(相关搜索:信噪比,系统容量)
  • ¥500 52810做蓝牙接受端
  • ¥15 基于PLC的三轴机械手程序
  • ¥15 多址通信方式的抗噪声性能和系统容量对比
  • ¥15 winform的chart曲线生成时有凸起
  • ¥15 msix packaging tool打包问题
  • ¥15 finalshell节点的搭建代码和那个端口代码教程