博客
关于我
python数据结构(四):带头结点的双链表
阅读量:709 次
发布时间:2019-03-21

本文共 4778 字,大约阅读时间需要 15 分钟。

带头结点的双链表的实现与带头结点的单链表的实现有相当高的相似性,最大的区别就是前者会多一个前驱结点指针域的操作。以下是对双链表实现的详细说明。

双链表的定义

双链表由两个方向的链表组成,每个结点不仅包含下一个结点的指针,还包含前一个结点的指针。通过这种方式,双链表支持的操作包括插入、删除、查找以及逆序遍历等。

双链表的实现

双链表的实现主要包含以下几个部分:

  • 结点类

    结点类 DoubleLinkedNode 定义了双链表的基本单元:

    class DoubleLinkedNode(object):    def __init__(self, data):        self.data = data        self.next = None        self.prev = None
  • 双链表类

    双链表类 DoubleLinkedList 负责管理整个双链表的逻辑:

    class DoubleLinkedList(object):    def __init__(self):        self.head = DoubleLinkedNode("头结点")
  • 双链表的操作方法

    双链表支持的主要操作包括:

    • 判断链表是否为空:
      def IsEmpty(self):    if self.GetLength() == 0:        print("该链表为空!")        return True    else:        return False
    • 获取链表长度:
      def GetLength(self):    currentNode = self.head.next    length = 0    while currentNode != None:        length += 1        currentNode = currentNode.next    return length
    • 遍历链表:
      def Traval(self):    if self.IsEmpty():        return    currentNode = self.head    print("当前链表为:")    while currentNode != None:        print(currentNode.data, end="<-> ")        currentNode = currentNode.next    print("")
    • 尾部插入元素:
      def InsertElementInTail(self):    element = input("待从尾部插入的结点的数据:")    if element == "#":        return    currentNode = self.head    newNode = DoubleLinkedNode(element)    while currentNode.next != None:        currentNode = currentNode.next    currentNode.next = newNode    newNode.prev = currentNode    self.Traval()
    • 头部插入元素:
      def InsertElementInHead(self):    element = input("待从头部插入的结点的数据:")    if element == "#":        return    newNode = DoubleLinkedNode(element)    newNode.next = self.head.next    self.head.next = newNode    newNode.prev = self.head    self.Traval()
    • 指定位置插入元素:
      def InsertElementInSpecifiedPosition(self):    Pos = 0    currentNode = self.head    element, position = input("结点的数据 待插入的结点在双链表中的位置").split(" ")    position = int(position)    if position < 1 or position > self.GetLength() + 1:        print("位置不合法!请重新确定位置!")        return    newNode = DoubleLinkedNode(element)    while currentNode.next != None:        Pos += 1        if Pos == position:            newNode.next = currentNode.next            currentNode.next = newNode            newNode.prev = currentNode            self.Traval()            return        else:            currentNode = currentNode.next
    • 查找指定数据的所有结点:
      def FindElement(self):    Position = []    Pos = 0    currentNode = self.head    element = input("待查找的数据:")    if self.IsEmpty():        print("当前双链表为空!无法查找!")        return    while currentNode.next != None:        currentNode = currentNode.next        Pos += 1        if currentNode.data == element:            Position.append(Pos)    if Position:        print("查找成功,值为", element, "的结点位于该双链表的第", Position, "位。")    else:        print("查找失败!当前双链表中不存在含有", element, "的结点")
    • 删除指定位置的结点:
      def DeleteElementInSpecifiedPosition(self):    print("在指定位置删除结点")    Pos = 0    currentNode = self.head    position = int(input("待删除的位置:"))    if self.IsEmpty():        print("当前双链表为空!无法删除结点!")        return    if position < 1 or position > self.GetLength():        print("位置不合法!请重新确定位置!")        return    while currentNode.next != None:        removedNode = currentNode.next        Pos += 1        if Pos == position:            currentNode.next = removedNode.next            if removedNode.next == None:                del removedNode            else:                removedNode.next.prev = currentNode                del removedNode        else:            currentNode = currentNode.next    self.Traval()
    • 删除所有指定数据的结点:
      def DeleteElement(self):    if self.IsEmpty():        print("当前双链表为空!")        return    element = input('请输入待删除结点的值:')    currentNode = self.head    while currentNode.next != None:        removedNode = currentNode.next        if removedNode.data == element:            currentNode.next = removedNode.next            if currentNode.next == None:                del removedNode            else:                removedNode.next.prev = currentNode                del removedNode        else:            currentNode = currentNode.next    print("成功删除所有含值为", element, "的结点")    self.Traval()
    • 销毁链表:
      def Destory(self):    print("正在销毁该链表...")    del self.head    print("已销毁该双链表!")
  • 示例操作

    以下是双链表的实际操作示例:

  • 创建双链表并添加元素

    dl = DoubleLinkedList()dl.Create()  # 调用创建方法
    • 输入元素时按下 Enter 以继续,或输入 # 以关闭。
    • 创建后的双链表初始结构为:头结点->1->2->3->4->
  • 尾部插入元素

    dl.InsertElementInTail()
    • 输入 4 将从尾部插入,链表变为:头结点->0->1->2->3->4->4
  • 头部插入元素

    dl.InsertElementInHead()
    • 输入 0 将从头部插入,链表变为:头结点->0->0->1->2->3->4->4
  • 指定位置插入元素

    dl.InsertElementInSpecifiedPosition()
    • 输入 100 和位置 1 将从头部插入,链表变为:头结点->100->0->0->1->2->3->4->4
  • 查找特定数据的所有结点

    dl.FindElement()
    • 输入 4 查找结果显示存在两个结点,分别位于第 6 位和 7 位。
  • 删除指定位置的结点

    dl.DeleteElementInSpecifiedPosition()
    • 删除位置 1 的结点 0,链表变为:头结点->0->1->2->3->4->4
  • 删除所有特定数据的结点

    dl.DeleteElement()
    • 输入 4 删除所有数据为 4 的结点,链表变为空:头结点->
  • 如需进一步了解双链表的实现和操作方法,可以在 技术文献 中查找更多相关资料。

    转载地址:http://jnzrz.baihongyu.com/

    你可能感兴趣的文章
    NIFI1.21.0_java.net.SocketException:_Too many open files 打开的文件太多_实际操作---大数据之Nifi工作笔记0051
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_插入时如果目标表中已存在该数据则自动改为更新数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0058
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0_Postgresql和Mysql同时指定库_指定多表_全量同步到Mysql数据库以及Hbase数据库中---大数据之Nifi工作笔记0060
    查看>>
    NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
    查看>>
    NIFI1.21.0最新版本安装_配置使用HTTP登录_默认是用HTTPS登录的_Https登录需要输入用户名密码_HTTP不需要---大数据之Nifi工作笔记0051
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增加修改实时同步_使用JsonPath及自定义Python脚本_03---大数据之Nifi工作笔记0055
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
    查看>>
    NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现update数据实时同步_实际操作05---大数据之Nifi工作笔记0044
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
    查看>>