数据结构--创建链表--Python

源码

python 复制代码
#封装普通节点的类
class Node:
    #构造函数,定义结点的属性
    def __init__(self, data):
        self.data = data  #普通结点的数据域
        self.next = None  #普通结点的连接域,刚构造的结点该位置域为空


#封装链表的类(封装头节点)
class Linklist:
    def __init__(self, node=None):
        self.size = 0  #头结点的数据域为0 链表的长度为0
        self.head = node  #头结点的连接域指向None

    #判空
    def is_empty(self):
        return not self.head

    #   return self.size==0  或者判断长度是否为零
    #头插
    def add_head(self, value):
        #创建一个新的结点
        node = Node(value)
        node.next = self.head
        self.head = node
        self.size += 1

    #尾插
    def add_tail(self, value):
        #创建一个结点node
        node = Node(value)
        #找最后一个结点
        # q = self.head
        # i=1
        # while i<self.size:
        #     q=q.next
        #     i+=1
        # q.next=node
        # self.size+=1
        #第二种方法
        q = self.head
        while q.next:
            q = q.next
        q.next = node
        self.size += 1
        #第三种
        # while True:
        #     q=q.next
        #     if not q.next:
        #         q.next = node
        #         self.size+=1
        #         break

    #任意位置插
    def add_any(self, id, value):
        node = Node(value)
        if id == 1:
            self.add_head(value)
        elif id == self.size+1:
            self.add_tail(value)
        elif id>self.size+1:
            print('插入失败')
            return
        else:
            q = self.head
            i = 1
            while i < id - 1:
                q = q.next
                i += 1
            node.next = q.next
            q.next = node
            self.size += 1

    #头删
    def del_head(self):
        self.head = self.head.next
        self.size -= 1

    #尾删
    def del_tail(self):
        if self.size==1:
            self.head=None
        else:
            q = self.head
            for i in range(self.size - 2):
                q = q.next
            q.next = None
            self.size -= 1
    #任意位置删
    def del_any(self,id):
        if id==1:
            self.del_head()
        else:
            q = self.head
            for i in range(id - 2):
                q = q.next
            q.next = q.next.next
            self.size -= 1
    #遍历
    def show(self):
        #判空
        if self.is_empty():
            print('遍历失败')
            return
        else:
            q = self.head
            while q:
                print(q.data, end=' ')
                q = q.next
            print()
    #任意位置修改
    def change_id(self,id,value):
        if id==1:
            self.head.data=value
        else:
            q=self.head
            for i in range(id-1):
                q=q.next
            q.data=value
    #按值修改
    def change_value(self,value,new_value):
        q=self.head
        while q:
            if q.data==value:
                q.data=new_value
                break
            q=q.next
    #按值查找返回位置
    def return_id(self,value):
        q=self.head
        i=1
        while q:
            if q.data==value:
                print(i)
                return
            q=q.next
            i+=1
        else:
            print('没有该值')
    #链表的翻转
    def reverse(self):
        prev = None
        current = self.head
        while current:
            next_node = current.next
            current.next = prev
            prev = current
            current = next_node
        self.head = prev




#测试
if __name__ == '__main__':
    #创建链表
    linklist = Linklist()
    linklist.add_head(10)
    linklist.add_head(20)
    linklist.add_head(30)
    linklist.add_head(40)
    linklist.add_head(50)
    linklist.add_tail(50)
    # linklist.add_any(8, 100)
    # linklist.del_head()
    linklist.del_tail()
    linklist.del_any(2)
    linklist.change_id(2,80)
    linklist.change_value(80,40)
    linklist.return_id(40)
    linklist.reverse()
    #遍历
    linklist.show()
相关推荐
screenCui10 分钟前
macOS运行python程序遇libiomp5.dylib库冲突错误解决方案
开发语言·python·macos
小眼睛羊羊18 分钟前
pyinstaller打包paddleocr
python
java1234_小锋22 分钟前
基于Python的旅游推荐协同过滤算法系统(去哪儿网数据分析及可视化(Django+echarts))
python·数据分析·旅游
蓝婷儿24 分钟前
Python 机器学习核心入门与实战进阶 Day 4 - 支持向量机(SVM)原理与分类实战
python·机器学习·支持向量机
%d%d21 小时前
python 在运行时没有加载修改后的版本
java·服务器·python
码农Cloudy.2 小时前
C语言<数据结构-链表>
c语言·数据结构·链表
amazinging2 小时前
北京-4年功能测试2年空窗-报培训班学测开-第四十七天
python·学习·selenium
YuTaoShao2 小时前
【LeetCode 热题 100】148. 排序链表——(解法二)分治
java·算法·leetcode·链表
Freak嵌入式2 小时前
一文速通 Python 并行计算:13 Python 异步编程-基本概念与事件循环和回调机制
开发语言·python·嵌入式·协程·硬件·异步编程
一个天蝎座 白勺 程序猿2 小时前
Python练习(1)Python基础类型操作语法实战:20道实战题解与案例分析(上)
开发语言·python·学习