链表

本文详细介绍了链表数据结构,包括单链表、双向链表和单向循环链表的概念、特点及Python实现。单链表由数据区和链接区组成,访问需要遍历;双向链表每个节点包含prev、elem和next,添加和删除操作相对复杂;单向循环链表则通过尾节点指向头节点形成循环。链表与顺序表相比,有其独特的优势和应用场景。
摘要由CSDN通过智能技术生成

单链表

线性表有两种:顺序表和链表

  1. 单链表
    链表的一个结点包含 数据区和链接区。
    箭头方向为单方向的为单向链表,也叫单链表。需要有一个头节点p指向单链表的头第一个节点的位置,表示单链表的地址,最后一个位置为尾结点,指向空。
    在这里插入图片描述
  2. python中如何赋值变量的本质
    a=10
    先找到一块内存,存放整数10,然后再找到一块内存a,存放整数10所在的地址,从而建立连接。a=10 表示a所存储的内容指向10所在的地址。等号前面是存放地址,等号右边是对象。
    将两个变量的值互换 a,b=b,a
    设a=10,b=20,则此代码表示的含义是:将b所指向的对象10所在的地址存到内存a里,将a所指向的对象20所在的地址存到b上。结果就是将a和b所指向的地址变了一下,10和20的地址没变。
    在这里插入图片描述
  3. 设置节点 python代码
class Node(object):
    "节点"      #类文档字符串,可通过ClassName.__doc__查看
    def __init__(self,elem):   #构造函数
        self.elem = elem
        self.next = None
  1. 设置单链表及各种属性 python代码
class SingleLinkList(object):
    "单链表"
    def __init__(self,node=None): #头节点默认为空,若不输入则为空链表
        self.__head = node  #将头节点设为私密属性
    def is_empty(self):
        "判断是否为空链表"
        return self.__head == None
    def length(self):
        "求链表长度"
        #current游标,用来移动遍历节点
        cur = self.__head
        #count记录数量
        count = 0
        while cur != None:
            count += 1
            cur = cur.next
        return count
    def travel(self):
        "遍历整个链表"
        cur = self.__head
        while cur != None:
            print(cur.elem, end = ' ') #打印完一个元素用空格隔开,不加end默认换行
            cur = cur.next
        print('')  #换行
    def append(self,item):
        "在尾部添加元素,尾插法"
        node = Node(item)
        if self.is_empty():
            self.__head = node
        else:
            cur = self.__head
            while cur.next != None:
                cur = cur.next
            cur.next = node
    def addFirst(self,item):
        "在头部添加元素,头插法"
        node = Node(item)
        node.next = self.__head
        self.__head = node
    def insert(self,index,item):
        """在指定位置添加元素
        :param index 从0开始
        """
        node = Node(item)
        if index <= 0
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值