首页 > 其他分享 >双向链表

双向链表

时间:2023-01-20 22:11:16浏览次数:43  
标签:cur self next 链表 item singlelist 双向

  双向链表既可以向前,也可以向后,其节点是由两个指针域,一个指向上一个节点,一个指向下一个节点,和一个数据域构成的。第一个节点的指向前一个指针为None,最后一个节点指向下一个为None

  

  代码实现:

  

# -*- coding = utf-8 -*-
# @Author: Wchime
# @time: 2023/1/20 20:34
# @file: 双向链表.py


class Nodes(object):
    """双向链表节点"""
    def __init__(self, item):
        self.item = item
        self.next = None
        self.prev = None


class DoubleLinkList(object):
    """
    双向链表
    """
    def __init__(self, node=None):
        self.__link = node

    def is_empty(self):
        # 链表是否为空
        return self.__link is None

    def get_length(self):
        """
        获取链表长度
        :return:
        """
        cur = self.__link
        count = 0
        while cur is not None:
            count += 1
            cur = cur.next
        return count

    def append(self,item):
        """
        添加节点, 当链表不是空链表时,需要找到最后一个节点
        :param item:
        :return:
        """
        node = Nodes(item)
        if self.is_empty():
            self.__link = node
        else:
            cur = self.__link
            while cur.next is not None:
                cur = cur.next
            cur.next = node
            node.prev = cur

    def insert(self, index, item):
        """
        在指定位置插入节点,插入在第n个时,需要将第m-n+1个元素向后移动位置
        :param index: 位置下标
        :param item: 插入值
        :return:
        """
        if index <=0:
            node = Nodes(item)
            node.next = self.__link
            self.__link = node
            node.next.prev = node
        elif index > self.get_length()-1:
            self.append(item)
        else:
            cur = self.__link
            count = 0
            while count < index:
                count += 1
                cur = cur.next
            node = Nodes(item)
            node.next = cur
            node.prev = cur.prev
            cur.prev.next = node
            cur.prev = node

    def remove(self, item):
        """
        根据值删除节点
        :param item:
        :return:
        """
        cur = self.__link
        while cur is not None:
            if cur.item == item:
                if cur == self.__link:
                    self.__link = cur.next
                    if cur.next:
                        # 判断链表是否只有一个节点
                        cur.next.prev = None
                else:
                    cur.prev.next = cur.next
                    if cur.next:
                        cur.next.prev = cur.prev
                break
            else:
                cur = cur.next

    def search(self, item):
        """
        查找节点是否存在
        :param item:
        :return:
        """
        cur = self.__link
        while cur is not None:
            if cur.item == item:
                return True
            else:
                cur = cur.next
        return False
    def travel(self):
        """
        链表遍历
        :return:
        """
        cur = self.__link
        while cur is not None:
            print(cur.item, end="  ")
            cur = cur.next
        print("")


if __name__ == "__main__":

    singlelist = DoubleLinkList()
    singlelist.append(1)
    singlelist.append(7)
    singlelist.append(5)
    singlelist.travel()

    singlelist.insert(1, 66)
    singlelist.travel()

    length = singlelist.get_length()
    print(length)

    print(singlelist.search(66))

    singlelist.remove(66)
    singlelist.travel()

    print(singlelist.is_empty())

 

标签:cur,self,next,链表,item,singlelist,双向
From: https://www.cnblogs.com/moon3496694/p/17063322.html

相关文章

  • 单向循环链表
    单向循环链表,相对于单向链表来说区别就是尾节点不再是指向None,而是指向头节点。 代码实现#-*-coding=utf-8-*-#@Author:Wchime#@time:2023/1/2015:31......
  • 【LeetCode链表#12】链表相交
    链表相交同:160.链表相交力扣题目链接(opensnewwindow)给你两个单链表的头节点headA和headB,请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点,返回n......
  • 单向链表
    单向链表的方向是单向的,其节点是由一个数据域和一个指针域组成,每个指针域都指向下一个节点,最后一个节点的指针域为None代码实现:#-*-coding=utf-8-*-#......
  • 【LeetCode链表#11】环形链表||(双指针)
    环形链表II力扣题目链接(opensnewwindow)题意:给定一个链表,返回链表开始入环的第一个节点。如果链表无环,则返回null。为了表示给定链表中的环,使用整数pos来表示链......
  • 一道合并有序链表的题
     /** *Definitionforsingly-linkedlist. *structListNode{ *  intval; *  ListNode*next; *  ListNode():val(0),next(nullptr)......
  • 顺序链表
    #include<iostream>#defineMAXSIZE100#defineERROR0#defineOK1usingnamespacestd;typedefstruct{ int*elem; in......
  • 【LeetCode链表#10】删除链表中倒数第n个节点(双指针)
    删除链表倒数第N个节点力扣题目链接(opensnewwindow)给你一个链表,删除链表的倒数第n个结点,并且返回链表的头结点。进阶:你能尝试使用一趟扫描实现吗?示例1:输入:hea......
  • 程序员代码面试指南第二版 12.打印两个升序链表的公共部分
    ​​welcometomyblog​​程序员代码面试指南第二版12.打印两个升序链表的公共部分题目描述题目描述给定两个升序链表,打印两个升序链表的公共部分。输入描述:第一个链表......
  • [数据结构]双向链表(C语言)
    双向链表双向链表概念双向链表也叫双链表,其每个数据结点中都有两个指针,分别指向直接后继和直接前驱。在单向链表中若要找到某个节点的前驱节点,需要先遍历到这个节点,然后......
  • 【LeetCode链表#9】图解:两两交换链表节点
    两两交换链表中的节点力扣题目链接(opensnewwindow)给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。你不能只是单纯的改变节点内部的值,而是需要实际的进行节......