爱python的小吴 2022-09-25 00:34 采纳率: 50%
浏览 20
已结题

python单链表尾部添加节点报错,逻辑貌似没问题啊,求解答!

问题遇到的现象和发生背景

python实现单链表尾部添加节点报错

运行结果及报错内容
class Node:
    def __init__(self,data):
        self.data=data
        self.next=None
        return
    def has_value(self,value):
        if self.data==value:
            return True
        else:
            return False
class singlelink:
    def __init__(self):
        self.head=None
        self.tail=None
        self.length=0
        return
    def isempty(self):
        return self.length==0
    def add_node(self,item):
        if not isinstance(item,Node):
            item=Node(item)
        if self.head is None:
            self.head=item
        else:
            self.tail.next=item
            self.tail=item
        self.length+=1
        return
    def insert_node(self,index,data):
        if self.isempty():
            print("this link is empty!")
            return
        if index<0 or index>=self.length:
            print("error:out of index!")
            return
        item=Node(data)
        if index==0:
            item.next=self.head
            self.haed=item
            self.length+=1
            return
        j=0
        node=self.head
        prev=self.head
        while node.next and j<index:
            prev=node
            node=node.next
            j+=1
        if j==index:
            item._next=node
            prev._next=item
            self.length+=1
    def delete_node_byid(self,item_id):
        id=1
        current_node=self.head
        previous_node=None
        while current_node is not None:
            if id==item_id:
                if previous_node is not None:
                    previous_node.next=current_node.next
                else:
                    self.head=current_node.next
                    return
            previous_node=current_node
            current_node=current_node.next
            id=id+1
        self.length-=1
        return
    def find_node(self,value):
        current_node=self.head
        node_id=1
        results=[]
        while current_node is not None:
            if current_node.has_value(value):
                results.append(node_id)
            current_node=current_node.next
            node_id=node_id+1
        return
    def print_link(self):
        current_node=self.head
        while current_node is not None:
            print(current_node.data)
            current_node=current_node.next
        return
Node1=Node(1)
Node2=Node(2)
Node3=Node(3)
link=singlelink()
for node in [Node1,Node2,Node3]:
    link.add_node(node)
link.print_link()

runfile('C:/Users/Administrator/.spyder-py3/temp.py', wdir='C:/Users/Administrator/.spyder-py3')
Traceback (most recent call last):

  File ~\.spyder-py3\temp.py:90 in <module>
    link.add_node(node)

  File ~\.spyder-py3\temp.py:25 in add_node
    self.tail.next=item

AttributeError: 'NoneType' object has no attribute 'next'
  • 写回答

2条回答 默认 最新

  • 梦里逆天 2022-09-25 08:24
    关注

    img

    class Node:
        def __init__(self, data):
            self.data = data
            self.next = None
            return
    
        def has_value(self, value):
            if self.data == value:
                return True
            else:
                return False
    
    
    class singlelink:
        def __init__(self):
            self.head = None
            self.tail = None
            self.length = 0
            return
    
        def isempty(self):
            return self.length == 0
    
        def add_node(self, item):
            # print(isinstance(item, Node))
            # print('data', item.data)
            # print('next', item.next)
            # print(type(self.head))
            # print(type(self.tail))
            # print(self.tail)
            # print(self.head is None)
            # print(self.tail is None)
            if not isinstance(item, Node):
                item = Node(item)
            if self.head is None:
                self.head = item
                self.tail = item
            else:
                self.tail.next = item
                self.tail = item
            self.length += 1
            return
    
        def insert_node(self, index, data):
            if self.isempty():
                print("this link is empty!")
                return
            if index < 0 or index >= self.length:
                print("error:out of index!")
                return
            item = Node(data)
            if index == 0:
                item.next = self.head
                self.head = item
                self.length += 1
                return
            j = 0
            node = self.head
            prev = self.head
            while node.next and j < index:
                prev = node
                node = node.next
                j += 1
            if j == index:
                item._next = node
                prev._next = item
                self.length += 1
    
        def delete_node_byid(self, item_id):
            id = 1
            current_node = self.head
            previous_node = None
            while current_node is not None:
                if id == item_id:
                    if previous_node is not None:
                        previous_node.next = current_node.next
                    else:
                        self.head = current_node.next
                        return
                previous_node = current_node
                current_node = current_node.next
                id = id + 1
            self.length -= 1
            return
    
        def find_node(self, value):
            current_node = self.head
            node_id = 1
            results = []
            while current_node is not None:
                if current_node.has_value(value):
                    results.append(node_id)
                current_node = current_node.next
                node_id = node_id + 1
            return
    
        def print_link(self):
            current_node = self.head
            while current_node is not None:
                print(current_node.data)
                current_node = current_node.next
    
    
    Node1 = Node(1)
    Node2 = Node(2)
    Node3 = Node(3)
    link = singlelink()
    for node in [Node1, Node2, Node3]:
        # print(node.data)
        link.add_node(node)
    link.print_link()
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 10月3日
  • 已采纳回答 9月25日
  • 创建了问题 9月25日

悬赏问题

  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)