首页 > 其他分享 >单向循环链表

单向循环链表

时间:2023-01-20 17:11:57浏览次数:34  
标签:.__ cur self 单向 next 链表 item 循环 link

  单向循环链表,相对于单向链表来说区别就是尾节点不再是指向None,而是指向头节点。

 

代码实现

# -*- coding = utf-8 -*-
# @Author: Wchime
# @time: 2023/1/20 15:31
# @file: 单向循环链表.py


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


class SingleLoopList(object):
    """
    单向循环链表
    """
    def __init__(self, node=None):
        self.__link = node
        if node:
            node.next = node

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

    def get_length(self):
        """
        获取链表长度
        循环链表最后节点next不是None值,而是第一个节点
        :return:
        """
        if self.is_empty():
            return 0
        else:
            cur = self.__link
            count = 1
            while cur.next != self.__link:
                count += 1
                cur = cur.next
            return count

    def append(self, item):
        """
        添加节点, 当链表不是空链表时,需要找到最后一个节点, 最后节点的判断的等于第一个节点
        :param item:
        :return:
        """
        node = Node(item)
        if self.is_empty():
            self.__link = node
            node.next = node
        else:
            cur = self.__link
            while cur.next != self.__link:
                cur = cur.next
            cur.next = node
            node.next = self.__link

    def insert(self, index, item):
        """
        在指定位置插入节点
        :param index:
        :param item:
        :return:
        """
        # print(self.get_length())
        if index == 0:
            node = Node(item)
            if self.is_empty():
                self.__link = node
                node.next = node
                return
            cur = self.__link
            while cur.next != self.__link:
                cur = cur.next
            node.next = self.__link
            self.__link = node
            cur.next = node
        elif index > self.get_length()-1:
            self.append(item)

        else:
            pre = self.__link
            count = 0
            while count < index - 1:
                count += 1
                pre = pre.next
            node = Node(item)
            node.next = pre.next
            pre.next = node

    def remove(self, item):
        """
        根据值删除节点
        :param item:
        :return:
        """
        if self.is_empty():
            return
        cur = self.__link
        pre = None
        while cur.next != self.__link:
            if cur.item == item:
                if cur == self.__link:
                    # 头节点
                    rear = self.__link
                    while rear.next != self.__link:
                        rear = rear.next
                    self.__link = cur.next
                    rear.next = self.__link
                else:
                    # 中间节点
                    pre.next = cur.next
                return
            else:
                pre = cur
                cur = cur.next
        # 尾节点
        if cur.item == item:
            if cur == self.__link:
                self.__link = None
            else:
                pre.next = cur.next

    def search(self,item):
        """
        查找节点是否存在
        :param item:
        :return:
        """
        if self.is_empty():
            return False
        cur = self.__link
        while cur.next != self.__link:
            if cur.item == item:
                return True
            else:
                cur = cur.next
        if cur.item == item:
            return True
        return False

    def travel(self):
        """
        链表遍历
        :return:
        """
        if self.is_empty():
            return
        cur = self.__link
        while cur.next != self.__link:
            print(cur.item,end="  ")
            cur = cur.next
        print(cur.item)


if __name__ == "__main__":

    singlelist = SingleLoopList()
    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,循环,link
From: https://www.cnblogs.com/moon3496694/p/17062899.html

相关文章

  • 【LeetCode链表#12】链表相交
    链表相交同:160.链表相交力扣题目链接(opensnewwindow)给你两个单链表的头节点headA和headB,请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点,返回n......
  • JavaScript 中断forEach循环
    1、使用Array.prototype.some()方法代替some()方法会在找到第一个符合条件的元素时停止循环。例如:letarray=[1,2,3,4,5];array.some(function(element,inde......
  • 单向链表
    单向链表的方向是单向的,其节点是由一个数据域和一个指针域组成,每个指针域都指向下一个节点,最后一个节点的指针域为None代码实现:#-*-coding=utf-8-*-#......
  • 【LeetCode链表#11】环形链表||(双指针)
    环形链表II力扣题目链接(opensnewwindow)题意:给定一个链表,返回链表开始入环的第一个节点。如果链表无环,则返回null。为了表示给定链表中的环,使用整数pos来表示链......
  • 循环控制语句 之 with_together
    功能类似于:列表元素数量上要一一对应foriinzip([1,2,3],['a','b','c']):print(i)-hosts:alltasks:-name:debugdebug:msg:"{{item}}"......
  • 循环控制语句 之 with_indexed_items
    添加索引-hosts:alltasks:-name:debugdebug:msg:"{{item}}"with_indexed_items:-[1,2,3]-['a','b','c','d']-hosts:all......
  • 循环控制语句 之 with_together
    功能类似于:foriinzip([1,2,3],['a','b','c']):print(i)-hosts:alltasks:-name:debugdebug:msg:"{{item}}"with_together:......
  • 循环控制语句 之 with_nested
    嵌套循环可以理解为:foriin[1,2,3]:forjin['a','b','c','d']:print(i,j)-hosts:alltasks:-name:debugdebug:msg:"{{item......
  • 循环控制语句 之 with_list
    with_list不展开循环嵌套的列表。功能类似于foriinzip([1,2,3],['a','b','c']):print(i)-hosts:alltasks:-name:debugdebug:msg:"{{......
  • 用数字循环输出全小写字母, 97是a 98是b
    packagecom.fqs.demo;publicclassCharAB{//输出26个字母publicstaticvoidmain(String[]args){intend=97+26;//97是a;98是bfor(i......