栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

Python 实现单链表

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Python 实现单链表

Python 实现单链表
  • 创建节点类
  • 创建单链表
    • 测试一
    • 测试二
    • 测试三
    • 测试四
  • 总结

创建节点类
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。
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/323630.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号