首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何判断循环链表

实际上判断一个链表是否是循环的思路很简单,困扰我的反而是“带环链表是否就是循环链表”这个问题,穿梭于各中帖子、书本寻找答案终究找不到明确说明。...《大话数据结构》中循环链表的定义为:“将单链表中终端节点的指针端由空指针改为指向头结点,就使整个单链表形成一个环,这种头尾相接的单链表称为单循环链表,简称循环链表。”...也就是这个样子的: 然后呢,还有其他带环链表是这个样子的: 暂时先把这两种情况的链表都称为循环链表吧(有些书籍就是这样处理的),那么下面就进入主题: 判断一个链表是否循环,那还不简单!...只要判断有没有指向NULL的指针就好了嘛,如果没有指向NULL的指针,头结点又重复出现,那可定就是循环链表了!代码是这样的: 看起来太简单了是不是??如果说是,那么你就错误了。...这种判断方式只适合头尾相接的循环链表,像“6”形的循环链表会导致程序进入死循环。那么,还有啥子办法呢?

1.1K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【数据结构】线性表 ④ ( 循环链表循环链表 | 代码示例 - 使用 Java 实现 单循环链表 )

    一、循环链表 ( 单循环链表 ) 在 单链表 中 , 将 最后一个节点 的指针 指向 第一个节点 , 形成一个闭环 , 上述 头尾相连 的单链表 称为 " 单循环链表 " , 简称为 " 循环链表 "...; 在 循环链表 中 , 没有明确的 第一个节点 或 最后一个节点 ; 循环链表 可以 模拟 环形结构 数据 , 如 : 循环队列 ; 二、代码示例 - 使用 Java 实现 单循环链表 在下面的代码中..., 定义节点类 : Node 是 循环链表 中的节点 , 每个节点都包含 data 数据 和 指向下一个节点的指针 next ; 定义应用类 : CircularLinkedList 类中 , 定义了..., 然后判断 链表首元素 head 是否为空 , 链表首元素为空 , 即链表为空 ; 如果链表为空 , 我们将头指针 head 指向新节点 , 并将新节点的 next 指针 指向自身,以形成循环。...如果链表非空 , 我们遍历链表找到最后一个节点 , 并将其 next 指针 指向新节点 , 再将新节点的next指针指向头节点 ; 使用 Java 语言实现 单循环链表 : public class Node

    31530

    数据结构Java实现:循环链表和双向链表

    上篇教程给大家分享了单链表的概念,以及如何用 Java 实现一个单链表的结构:数据结构Java实现:单链表。...单链表是最基础的一种链表结构,在实际开发中的使用有一些局限性,比如只能单向往后查找节点,如果需要找到某元素的前驱节点,单链表是无法实现的,今天来给大家分享另外两个复杂一些的链表结构:循环链表和双向链表。...循环链表 循环链表本质上就是一种单链表,两者的不同之处在于链表中最后一个节点的指针指向哪里,在单链表中,末尾节点的指针指向空,如下图所示。 ?...而在循环链表中,末尾节点的指针指向首节点,形成一个闭环,所以它叫循环链表,应该很好理解,如下图所示。 ?...接下来用 Java 实现一个循环链表的结构,只需要在原有单链表的基础上稍作修改即可,如下所示。

    3.5K20

    【数据结构】线性表 ⑤ ( 双循环链表 | 双循环链表特点 | 双循环链表插入操作处理 | 代码示例 - 使用 Java 实现 双循环链表 )

    一、双循环链表 " 双循环链表 " 是 在 单循环链表 的基础上 , 在每个 节点 中 , 新增一个 指针 , 指向 该节点 的 前驱节点 ; 双向循环链表 每个 节点 都包含 数据 和 两个指针 ,...一个指针指向前一个节点 , 一个指针指向后一个节点 ; 与 单循环链表相比 , 双循环链表 可以在两个方向上遍历整个链表 , 单循环链表 只能在一个方向上遍历链表 ; 二、双循环链表特点 双循环链表 特点...: 双循环链表 中 , 可以在 任意位置 增删节点 , 双循环链表中可以双向遍历 , 增删节点 效率更高 ; LRU 缓存算法中 , 一般使用 双循环链表 数据结构 ; 三、双循环链表插入操作处理 双循环链表...插入节点操作 需要执行四个步骤 : ① 将 c 的 前驱指针 指向 a ② 将 a 的 后继指针 指向 c ③ 将 c 的 后继指针 指向 b ④ 将 b 的 前驱指针 指向 c 四、代码示例 - 使用 Java...Java 实现 双循环链表 : public class Node { public int data; public Node prev; public Node next;

    21620

    循环链表的实现_建立双向循环链表

    循环链表   循环链表是一个收尾相接的链表,将单链表的最后一个指针域改由NULL改为指向表头结点这就是单链式的循环链表,并称为循环链表   带头结点的循环链表的各种操作的算法实现与带头结点单链表的算法实现类似...单链表中的判别条件为p!=NULL或p->next!=NULL,而单循环链表判别条件是p!=L或p->next!=L   在循环链表中附设尾指针有时候比附设头指针更简单。...如:在用头指针的循环链表中找a1的时间复杂度是O(1),找an需要从头找到尾,时间复杂度是O(n),如果用为指针rear,找开始结点和终端结点的存储位置分别是rear->next->next和rear...建立循环链表 void CreatCLLinkList(CLLinkList CL) { Node *rear,*s; rear=CL;//rear指针动态指向当前表尾,其初始值指向头结点...    方法一:先找到两个链表LA,LB的表尾,分别用p,q指向它,然后将第一个链表的表尾与第二个链表的第一个结点连起来,修改第二个表的尾q,使它的链域指向第一个表头 //头指针合并循环链表 #include

    74920

    循环链表-带头双向循环链表的实现

    带头双向循环链表   前言   对于链表来说,不只有单链表这一个品种;   链表有很多种形态   按方向分:单向、双向   按带不带头:带头、不带头   按循环循环、不循环   1、单向或则双向:...  2、带头或者不带头:   3、循环或者不循环:   组合排列一下的话,链表一共有8种形态!!!   ...今天我们就来学习一下结构最复杂的带头双向循环链表!!!...;   虽然名字听上去比较复杂单循环链表,但是实现起来比单链表(全名:不带头、不循环、单向链表)更加简单,也不需要过多考虑特殊情况;   两种链表的比较:(上面是单链表,下面是带头双向循环链表)   结构分析...  首先链表的头节点是不存储有效数据的(该节点被称为哨兵位),其次我们只需要知道改头节点的指针就能找到整个链表循环链表,并且便于对整个链表进行维护;   当然既然是双向的嘛,那节点一定有个指针域指向前一个节点

    60730

    JS 循环链表

    ---导文循环链表是一种特殊的链表数据结构,其中最后一个节点指向链表的头节点,形成一个循环的环状结构。与普通链表不同,循环链表没有明确的结束点,可以通过任意节点开始遍历整个链表。...循环链表的概念循环链表是一种链表的变体,其中链表中的最后一个节点指向链表的头节点,形成一个循环或环状结构。与普通链表不同,循环链表没有明确的结束点。...在 JavaScript 中,我们可以使用对象或类来表示循环链表。创建链表节点对象,通过赋值和指针操作来构建循环链表,并确保最后一个节点的指针指向头节点,形成循环。...循环链表具有以下几个特点:循环性:循环链表是通过将最后一个节点指向头节点来形成循环的闭合结构。这意味着链表中没有明确的结束点,可以从任何节点开始遍历整个链表,直到回到原始出发节点。...场景应用:循环链表常用于需要循环遍历的场景。例如,在游戏开发中,可以使用循环链表来实现循环列表,遍历玩家角色队列;在轮播图或循环播放的场景中,可以使用循环链表来管理展示内容的顺序。

    15010

    java基础(三):条件判断循环,类与对象

    一.条件判断(控制语句) if ... else ... if(条件){ 代码段1; } else { 代码段2; } switch switch(表达式){ case 值1...循环 while循环 while ( 循环条件 ) { 循环操作 } 特点:先判断,再执行 循环结构都由如下四个结构组成: 初始化、条件判断循环体、迭代 do-while循环 do{...循环操作 } while (循环条件); 特点:先执行,后判断 相对于while循环,do-while循环至少执行一次。...对象是Java程序的核心,在Java程序中“万事万物皆对象”。 JDK提供了很多类供编程人员使用,编程人员也可定义自己的类。...属性作用范围是整个类体 在定义成员变量时可以对其初始化,如果不对其初始化,Java使用默认的值对其初始化。

    59220

    【数据结构】线性表 ⑥ ( 双循环链表 | 双循环链表插入操作 | 双循环链表删除操作 | LinkedList 双循环链表源码分析 )

    一、双循环链表插入操作处理 双循环链表 中 , 需要对 插入 / 删除 / 遍历 操作 进行特殊处理 , 因为需要调节 前驱指针 和 后继指针 两个指针 ; 如 : 双循环链表 中 , 如果要插入元素...---- 下面的链表插入成功 , 顺序为 a , c , b , 如果要删除双循环链表中的 c 元素 , 只需要将 a 元素的 后继指针 指向 b , 将 b 元素的 前驱指针 指向 a 即可 ;.../9.0.0_r8/xref/libcore/ojluni/src/main/java/java/util/LinkedList.java 1、链表节点 LinkedList 链表是一个 双循环链表 ,.../java/util/LinkedList.java#1021 2、LinkedList 链表中收尾元素指针 在 LinkedList 双循环链表中 , 维护了 首元素节点指针 transient Node.../java/util/LinkedList.java#596 6、删除指定索引的元素 LinkedList 双循环链表 中 , 调用 public E remove(int index) 函数 , 删除指定索引的元素

    24520

    如何判断回文链表

    判断一个字符串是不是回文串就简单很多,不需要考虑奇偶情况,只需要「双指针技巧」,从两端向中间逼近即可: func isPalindrome( s string)bool { str:=[]rune...下面扩展这一最简单的情况,来解决:如何判断一个「单链表」是不是回文。...一、判断回文单链表 输入一个单链表的头结点,判断这个链表中的数字是不是回文: /** * 单链表节点的定义: type ListNode struct { val int next...三、最后总结 首先,寻找回文串是从中间向两端扩展,判断回文串是从两端向中间收缩。对于单链表,无法直接倒序遍历,可以造一条新的反转链表,可以利用链表的后序遍历,也可以用栈结构倒序处理单链表。...具体到回文链表判断问题,由于回文的特殊性,可以不完全反转链表,而是仅仅反转部分链表,将空间复杂度降到 O(1)。

    89020

    链表回文判断

    判断一个单链表是否为回文链表目前有两种实现思路。一种是通过数组记录前半部分与后半部分依次比较,一种是找到链表中间结点,将左半部分反转与右半部分依次比较,下面详细介绍。...基于栈的回文判断 思路同基于数组的,但因为免去了保存新结点的右移操作,所以比使用数组保存左侧数据的方式高效一些。...} curr = curr.next; i++; } return true; } 基于链表反转的回文判断.../** * 不含逻辑头节点的回文链表判断 * 思路: * 遍历一遍链表,得到链表长度n,根据长度的奇偶,找到中间节点,将左半边的链表反转,然后从中间节点分两个方向向左右两边遍历...,是否是回文; * * 对左半部分链表进行反转,还原为最初的链表(目前函数未实现左半部分链表还原) * * * 1 2 3 4 5 8 9 slow

    50620
    领券