Python重现数据结构--链表的实现(单链表)

链表的介绍

链表(linked_list)是物理存储单元上非连续的、非顺序的存储结构,数据元素的逻辑顺序是通过链表的指针地址实现,每个元素包含两个结点,一个是存储元素的数据域 (内存空间),另一个是指向下一个结点地址的指针域。根据指针的指向,链表能形成不同的结构,例如单链表,双向链表,循环链表等。

在这里插入图片描述

链表通过将链点 i 与其邻居链点 i+1 通过指针相关联,从索引 0 到索引 N-1 对链点进行排序。

直接上代码

#File name:单链表的实现
#Author: 龙文汉
#Version: 1.0
#Date: 2020.10.4
#Description:

class Node:
    def __init__(self,data):
        self.data = data #链表的元素值
        self.next = None #下一个节点


class Linked_listed:
    def __init__(self,head=None): #链表初始化
        self.head = Node(None) #头元素
        self.head.next = None
        self.length = 0

    def Append(self, new_element):#向链表添加节点
        current = self.head
        #头节点存在
        while current.next:
            current = current.next
        current.next = new_element
        self.length += 1

    def Is_empty(self):#判断链表是否为空
        return self.length == 0

    def Insert(self, position, new_element):#插入新元素
        position -= 1
        if position < 0 or position > self.length+1:
            raise IndexError('插入时,插入位置不规范!')
        temple = self.head  #临时坐标
        for i in range(0, self.length+1):
            if position == i:
                new_element.next = temple.next
                temple.next = new_element
            else:
                temple = temple.next
        self.length += 1

    def Remove(self, position): #删除接节点
        position -= 1
        if position < 0 or position >= self.length:
            raise IndexError("删除元素位置索引超出范围")
        temple = self.head
        for i in range(0, self.length):
            if position == i:
                temple.next = temple.next.next
            else:
                temple = temple.next
        self.length -= 1

    def Get_length(self):#获取链表长度
        return self.length

    def Print(self):#打印链表
        print("Linked_list:")
        temple = self.head
        while temple.next != None:
            temple = temple.next
            print(temple.data)

    def Reserve(self):#反转链表
        temple = self.head
        prev = Node(None)
        prev.next = None

        for i in range(0,self.length):
            re_tem = temple.next
            temple.next = re_tem.next

            re_tem.next = None
            re_tem.next = prev.next
            prev.next = re_tem

        self.head = prev


    def Initlist(self, data_list):#列表转链表
        temple = self.head
        self.length = len(a)
        for i in data_list:
            node = Node(i)
            node.next = temple.next
            temple.next = node

    def Change_data(self,position,new_element):
        if position < 0 or position > self.length:
            raise IndexError("Index Error!")
        temple = self.head
        for i in range(0,self.length+1):
            if i == position:
                temple.data = new_element.data
                return
            else:
                temple = temple.next

    def Search(self,new_element):
        temple = self.head
        for i in range(0,self.length+1):
            if new_element.data == temple.data:
                print("This Node's index is ",i)
            else:
                temple = temple.next

if __name__ == '__main__':
   # link_list = Linked_listed(None)
   # link_list.Append(Node(3))
   # link_list.Append(Node(23))
   # link_list.Insert(1,Node(65))
   # link_list.Insert(3,Node(5))
   # link_list.Insert(4, Node(16))
   # link_list.Insert(6, Node(416))
   #
   # link_list.Print()
   # link_list.Remove(2)
   # link_list.Remove(5)
   #
   # link_list.Print()
   # print(link_list.Is_empty(),link_list.Get_length())

   a = [3,2,5,75,45]
   b = Linked_listed(None)
   b.Initlist(a)
   b.Print()
   b.Reserve()
   b.Print()
   b.Change_data(5,Node(30))
   b.Print()
   b.Search(Node(30))

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Hanzoe_lwh

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值