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

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

上篇教程给大家分享了单链表的概念,以及如何用 Java 实现一个单链表的结构:数据结构Java实现:单链表。...单链表是最基础的一种链表结构,在实际开发中的使用有一些局限性,比如只能单向往后查找节点,如果需要找到某元素的前驱节点,单链表是无法实现的,今天来给大家分享另外两个复杂一些的链表结构:循环链表和双向链表。...循环链表 循环链表本质上就是一种单链表,两者的不同之处在于链表中最后一个节点的指针指向哪里,在单链表中,末尾节点的指针指向空,如下图所示。 ?...接下来用 Java 实现一个循环链表的结构,只需要在原有单链表的基础上稍作修改即可,如下所示。...如果是双向链表的结构,每一个节点都会记录其前驱节点,可直接获取,所以此时的时间复杂度为 O(1)。 ? 搞清楚了双向链表的概念,接下来我们用 Java实现双向链表的结构。

3.5K20

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

循环链表   循环链表是一个收尾相接的链表,将单链表的最后一个指针域改由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
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

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

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

    31230

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

    带头双向循环链表   前言   对于链表来说,不只有单链表这一个品种;   链表有很多种形态   按方向分:单向、双向   按带不带头:带头、不带头   按循环循环、不循环   1、单向或则双向:...  2、带头或者不带头:   3、循环或者不循环:   组合排列一下的话,链表一共有8种形态!!!   ...;   虽然名字听上去比较复杂单循环链表,但是实现起来比单链表(全名:不带头、不循环、单向链表)更加简单,也不需要过多考虑特殊情况;   两种链表的比较:(上面是单链表,下面是带头双向循环链表)   结构分析...、这两个接口就能快速实现出带头双向循环链表了;   总代码及头文件   头文件的包含:    #pragma once #include #include #include...#include // 带头+双向+循环链表增删查改实现 typedef int LTDataType; typedef struct ListNode {

    60730

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

    一、双循环链表 " 双循环链表 " 是 在 单循环链表 的基础上 , 在每个 节点 中 , 新增一个 指针 , 指向 该节点 的 前驱节点 ; 双向循环链表 每个 节点 都包含 数据 和 两个指针 ,...一个指针指向前一个节点 , 一个指针指向后一个节点 ; 与 单循环链表相比 , 双循环链表 可以在两个方向上遍历整个链表 , 单循环链表 只能在一个方向上遍历链表 ; 二、双循环链表特点 双循环链表 特点...: 双循环链表 中 , 可以在 任意位置 增删节点 , 双循环链表中可以双向遍历 , 增删节点 效率更高 ; LRU 缓存算法中 , 一般使用 双循环链表 数据结构 ; 三、双循环链表插入操作处理 双循环链表...实现循环链表 Node类来表示双向循环链表的节点 , 每个节点包含如下要素 : 数据项 data ; 指向 前一个节点 的 前驱指针 prev ; 指向 下一个节点 的 后继指针 next ; 使用...Java 实现循环链表 : public class Node { public int data; public Node prev; public Node next;

    21620

    Python实现单向循环链表

    关于链表的介绍,请参考:链表介绍 本篇文章使用 Python 来实现一个单向循环链表。 一、定义一个创建节点的类 链表是由一个个的节点组成的,在创建链表之前,要先创建节点,然后把节点“串”到链表上。...__head = None 三、实现单向循环链表的展示功能 def is_empty(self): return not self....四、实现单向循环链表中添加数据的功能 def add(self, data): node = Node(data) if self.is_empty():...:", s.length()) 运行结果: 10 → 1 → 2 → 3 → 4 → 10 → 20 → 1 → 2 → 3 → 4 → 链表长度: 6 五、实现单向循环链表的查询和修改功能...→ 4 → 10 → 20 → 30 → 3 → 4 → 10 → 20 → 4 → 4 → 30 → 3 → 4 → 4 → 10 → 20 → 30 → 3 → 以上就是用 Python 实现的单向循环链表及单向循环链表的一些简单操作方法

    1K30

    如何实现双向循环链表

    引言 双向带头循环链表是一种常见的数据结构,它具有双向遍历的特性,并且在表头和表尾之间形成一个循环。本文将深入探讨双向带头循环链表的结构、操作和应用场景,帮助读者更好地理解和运用这一数据结构。...本篇博客将以图表和代码相结合的方式手撕双向带头循环链表,代码使用C语言进行实现。 1....在链表的表头和表尾之间会形成一个循环,使得链表可以从任意节点出发进行正向或反向的遍历。...我们要实现的是一个双向带头循环链表,所以在初始化的时候使哨兵节点的next指向自己,prev指向自己,这样的结构对后面对链表的操作会方便很多,提供了很大的便利。...在实现打印链表的时候我们先用一个assert断言来进行判断,如果phead使空的话就会报错停止运行,因为至少要保证有一个表头,要不然无法组成链表

    11910

    Python 实现单向循环链表

    循环链表的概念 1.什么是循环链表   所谓的循环链表就是让单向链表的首尾相连,组成一个环状。 2.循环链表的典型应用   约瑟夫环问题。...3.实现循环链表的重点   1,循环链表在插入第一个元素的时候,需要我们将第一元素的指针域指向其自身,也就构成了循环链表。   2,循环链表基于单向链表而生,单是比循环链表多了游标这个概念。...要想实现循环链表的插入,删除的关键是考虑头结点问题,因为在头插法方式(往链表的头部插入数据)中,需要将末尾数据元素的指针域指向新插入的节点。...usr/bin/env python # -*- coding:utf-8 -*- """ @author:yzk13 @time: 2018/04/17 单向循环链表 """ class...:', l.search(7)) # ------- 测试长度---------- print('链表长度为: ', l.length)

    1.5K60

    java 链表长度_Java实现单向链表

    一、前言 最近在回顾数据结构与算法,有部分的算法题用到了栈的思想,说起栈又不得不说链表了。...数组和链表都是线性存储结构的基础,栈和队列都是线性存储结构的应用~ 本文主要讲解单链表的基础知识点,做一个简单的入门~如果有错的地方请指正 二、回顾与知新 说起链表,我们先提一下数组吧,跟数组比较一下就很理解链表这种存储结构了...2.1回顾数组 数组我们无论是C、Java都会学过: 数组是一种连续存储线性结构,元素类型相同,大小相等 数组的优点: 存取速度快 数组的缺点: 事先必须知道数组的长度 插入删除元素很慢 空间通常是有限制的...需要大块连续的内存块 插入删除元素的效率很低 2.2链表说明 看完了数组,回到我们的链表链表是离散存储线性结构 n个节点离散分配,彼此通过指针相连,每个节点只有一个前驱节点,每个节点只有一个后续节点

    83020

    数据结构:双向链表实现队列与循环链表

    实现双向链表只需在《图示单链表的插入和删除操作》中代码的基础上改动两个地方。...在《队列的链式存储结构》中我们使用单链表实现队列的尾进头出,下面我们演示使用双向链表实现队列的头进尾出。...,就使整个单链表形成一个环,这种头尾相接的单链表就称为单循环链表, 简称循环链表(circular linked list)。...其实循环链表和单链表的主要差异就在于循环的判断条件上,原来是判断p->next是否为空,现在则是p->next不等于头结点,则循环未结束。...我们在《队列的顺序存储结构(循环队列)》中使用数组实现了环形队列,我们还要“假想”它是首尾相接的,而如果基于链表实现环形队列,我们本来就可以用指针串成首尾相接的。

    2K80

    Java实现链表

    链表 前言 一、链表的概念及结构 二、链表的分类 三、链表实现 无头单向非循环链表实现 无头双向链表实现 具体代码 四、链表习题 五、顺序表和链表的区别 前言 推荐一个网站给想要了解或者学习人工智能知识的读者...双向链表则允许节点同时指向前一个和下一个节点,这使得双向链表在某些操作上比单向链表更高效。循环链表则是将尾节点的指针指向头节点,形成一个闭环。 在实际应用中,链表常用于实现栈、队列和哈希表等数据结构。...带头双向循环链表:结构最复杂,一般用在单独存储数据。实际中使用的链表数据结构,都是带头双向循环链表。...三、链表实现 无头单向非循环链表实现 // 1、无头单向非循环链表实现 public class SingleLinkedList { //头插法 public void addFirst(int...public int size(); public void display(); public void clear(); } 具体代码 // 2、使用无头单向非循环链表实现 public class

    8710

    约瑟夫环问题(单向循环链表实现)

    这个游戏的实现只需将每个人的信息作为一个结点,节点中存放每个人的编号和密码,由于要反复做删除操作,所以采用单项循环链表实现较为方便。...算法分析: 采用单向循环链表的数据结构,即将链表的尾元素指针指向链首元素。每个结点除了指针域外,还有两个分别存放每个人的编号和所持有的密码。...解决问题的基本步骤如下: 1.建立n个结点(无头结点)的单向循环链表 2.从链表第一个结点开始循环计数寻找第m个结点。...NodeType *GetNode(int,int);//得到一个结点 void PrntList(NodeType *);//打印循环链表 int isEmptyList(NodeType *);/...printf("\n-----------------打印循环链表---------------\n"); PrntList(pHead); //打印循环链表 printf("

    37420

    DS:带头双向循环链表实现

    博主的上篇文章介绍了链表,以及单链表实现。 单链表实现(超详细!!) 其实单链表的全称叫做不带头单向不循环链表,本文会重点介绍链表的分类以及双链表实现!...1.3 循环或者不循环循环链表最后一个结点的next指针指向NULL,而循环链表,最后一个结点的next指针指向第一个结点!!...虽然有这么多的链表的结构,但是我们实际中最常用还是两种结构: 单链表(不带头单向不循环链表)和 双向链表(带头双向循环链表) 1. 无头单向非循环链表:结构简单,⼀般不会单独⽤来存数据。...;//保存的数据 struct ListNode* prev;//指针保存前一个结点的地址 struct ListNode* next;//指针保存后一个结点的地址 }LTNode; 四、带头双向循环链表实现...五、带头双向循环链表实现的全部代码 List.h #pragma once #include #include #include typedef

    11710

    【数据结构】—带头双向循环链表实现(完美链表

    目录 前言 链表实现 新节点的创建 链表初始化 尾插与尾删 头插与头删 查找数据 在任意位置的插入与删除 链表的销毁 总结 前言 链表结构一共有八种形式,在前面的文章里已经讲完了不带头单向非循环链表实现...,但是我们发现该链表实现尾插与尾删时比较麻烦,要先从头节点进行遍历,找到尾节点,时间复杂度为O(N),而本次所讲的带头双向循环链表,则可以直接找到尾节点。...虽然该链表看起来特别复杂,但实际上真正实现起来很简单,并且用起来真的超爽,还能拿来吹吹牛皮。唬一唬一知半解的外行人。...链表实现 typedef int LTDataType;//类型重命名 typedef struct ListNode { LTDataType _data;//数据 struct ListNode...空表状态下应该是如下图这样的,因为它是带头的循环链表,所以第一个节点不用来存储有效数据。

    60220

    Java实现单向链表

    确定一个链表我们只需要头指针,通过头指针就可以把整个链表都能推导出来了~ 链表又分了好几类: 单向链表 一个节点指向下一个节点 双向链表 一个节点有两个指针域 循环链表 能通过任何一个节点找到其他所有的节点...,将两种(双向/单向)链表的最后一个结点指向第一个结点从而实现循环 操作链表要时刻记住的是: 节点中指针域指向的就是一个节点了!...三、Java实现链表 算法: 遍历 查找 清空 销毁 求长度 排序 删除节点 插入节点 首先,我们定义一个类作为节点 数据域 指针域 为了操作方便我就直接定义成public了。.../** * 实现链表的反转 * * @param node 链表的头节点 */ public static Node reverseLinkList...= null),退出循环就会找到尾节点) 遍历链表 从首节点(有效节点)开始,只要不为null,就输出 给定位置插入节点到链表中 将原本由上一个节点的指向交由插入的节点来指向 上一个节点指针域指向想要插入的节点

    2.6K103
    领券