Python 实现单链表

本文详细介绍了如何用Python创建节点类和单链表,涵盖了链表的初始化、空判断、节点添加、遍历、查找、删除和插入等核心操作,并通过四个测试案例展示了链表的功能。同时,将单链表比作嵌套数组,解释了节点之间的连接方式。
摘要由CSDN通过智能技术生成

创建节点类

class Node():
    def __init__(self,Value):
        self.Value=Value
        self.Next=None

创建单链表


class SingleLinkList():
    
    # 初始化头节点,其为空节点
    def __init__(self,node=None):
        self.head=node

    # 判断单链表是否为空
    def is_Empty(self):
        return self.head==None

    # 在链表头部添加元素
    def add(self,item):
        new_node=Node(item)
        new_node.Next=self.head
        self.head=new_node
        
    # 遍历链表,并打印节点的值
    def travel(self,option=0):
        length=0
        first=self.head
        while first  !=  None:
            if option==1:
                print(first.Value,end=',')
            first=first.Next
            length=length+1
        print('\n')
        return length
    
    # 判断元素是否存在于链表中
    def is_exist(self,target):
        if self.is_Empty():
            return False
        else:
            first=self.head
            while 1:
                if first.Value==target:
                    return not False
                if first.Next==None:
                    break
                else:
                    first=first.Next
            return False
        
    # 在链表尾部添加元素 直接将原链表尾部结点的Next置为元素结点
    def append(self,last):
        if self.is_Empty():
            self.head=Node(last)
        else:
            first=self.head
            while 1:
                if first.Next==None:
                    break
                else:
                    first=first.Next
            first.Next=Node(last)

     # 移去元素,即先判断结点的下一个节点的值是否为目标元素,如果是,将节点的下一个节点置为节点的下一个节点的下一个节点
    def remove(self,target):
        first=self.head
        if first==None:
            raise Exception("链表为空!", level)
        elif first.Value==target:
            self.head=self.head.Next
        else:
            while 1:
                if first.Next.Value==target:
                    first.Next=first.Next.Next    # 将节点的下一个节点置为节点的下一个节点的下一个节点
                    break
                elif first.Next==None:
                    break
                else:
                    first=first.Next
                    
    # 插入元素,在正确位置LOCATION上,先把新结点的Next储存为 LOCATION的Next,再把 LOCATION的Next储存为新结点
    def insert(self,target,index):
        if index<=0:  # 直接置为头部
            self.add(target)
        elif index >= (self.travel()):  ## 直接置为尾部
            self.append(target)
        else:
            length=0
            first=self.head
            while first  !=  None:
                if length== (-1+index):
                    new_node=Node(target)   
                    new_node.Next=first.Next # 先把新结点的Next储存为 LOCATION的Next
                    first.Next=new_node    #再把 LOCATION的Next储存为新结点
                first=first.Next
                length=length+1
            return length

测试一

c=SingleLinkList( )
c.travel(1)
for v in range(3):
    c.add(v)
c.travel(1)

输出

空链表

2,1,0,

测试二

c=SingleLinkList( )
c.travel(1)
for v in range(3):
    c.append(v)
c.travel(1)

输出

空链表

0,1,2,

测试三

c=SingleLinkList( )
for v in range(3):
    c.append(v)
c.travel(1)
c.remove(1)
c.travel(1)

输出

0,1,2,

0,2,

测试四

c=SingleLinkList( )
c.travel(1)
for v in range(3):
    c.append(v)
c.insert(888,2)
c.travel(1)

输出

空链表

0,1,888,2,

总结

  • 可以将单链表看作数组的嵌套,最大的数组的名称永远是head,数组的第一位元素存储结点的值,数组的第二位元素存储该结点的子节点。
  • 如[1,[2,[3,None]]],也就是head结点为[1,[2,[3,None]]],下一个结点A为[2,[3,None]],A的下一个结点B为[3,None],B结点的下一个结点为None。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值