Java怎么判断一个链表有环
发表于:2024-10-14 作者:千家信息网编辑
千家信息网最后更新 2024年10月14日,这篇文章主要介绍了Java怎么判断一个链表有环,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。链表是常用的几种数据结构其中一个。链表结构
千家信息网最后更新 2024年10月14日Java怎么判断一个链表有环
这篇文章主要介绍了Java怎么判断一个链表有环,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
链表是常用的几种数据结构其中一个。链表结构可以充分利用计算机内存空间,实现灵动的内存动态管理。本篇文章将通过 Java 代码展示为大家介绍如何判断一个链表是个有环链表,以及有环链表的入口点。
1.首先定义一个单链表;
var ,next,是单链表中的属性,分别表示节点值和下一个节点的指向;
代码如下:
//定义一个链表 class List{ public int var; public List next;//有参构造 public List(int var) { this.var = var; }//无参构造 public List() { } //创建一个带环的链表 public List Create(){ List a = new List(1); List b = new List(2); List c = new List(3); List d = new List(4); List e = new List(5); List f = new List(6); a.next = b; b.next =c; c.next = d; d.next =e; e.next = f; f.next =d; return a; }
2.编写判断是否存在环
如果存在,则返回这个节点,如果不存在则返回null,定义快慢指针,如果快的追上了慢的指针,那么这个链表必存在环,如果没有追上,或者都为null,那么这个链表没有环;
代码如下:
//判断是否有环,并找到相遇的节点public List MeetingNode(List node){ List slow = new List(); List fast = new List(); if(node==null) return null; slow = node.next; if(slow==null) return null; fast=slow.next; while (fast!=null && slow!=null){ if (fast==slow){ return fast; //fast追上了slow,确定是一个有环的链表; } slow = slow.next; fast = fast.next; if(fast!=null){ fast = fast.next; } } return null;}
3.寻找入口节点
先让快指针先走环的节点的个数步,在让慢指针开始走,如果两个指针相遇的话,那么相遇的节点必然是环的入口节点
代码如下:
public List Enterdear(List node){ if(node==null) return null; if(MeetingNode(node)==null) return null; int count =1; List res2; List res1 = MeetingNode(node); while (res1.next!=MeetingNode(node)){ res1 = res1.next; count++; } res1 = node; for(int i = 0;imain函数测试;
public class Deom { public static void main(String[] args) { List SB = new List(); List res = SB.Create(); List dear= SB.Enterdear(res); System.out.println(dear.var); }}
感谢你能够认真阅读完这篇文章,希望小编分享的"Java怎么判断一个链表有环"这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!
节点
指针
代码
篇文章
入口
内存
结构
环链
两个
个数
价值
兴趣
函数
动态
同时
属性
常用
必然
快慢
指向
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
数据库前台收银
数据库生成json
然后把数据库连接到java
黑客攻击的是服务器还是程序
网络安全 银行宣传总结
传奇怎么进入服务器
影响计算机网络安全
基层软件开发
不用登陆直接打开服务器文档
服务器在国外的app能打开吗
日程计划软件开发
腾宏达网络技术
小米路由器开放网络安全吗
甘肃虚拟服务器管理软件云空间
数据库一周自动更新列值
外国网络安全审查
服务器磁盘满了无法备份
网络安全与数据
擎天软件为什么说数据库无效
JSP和数据库的连接技术
sql数据库空白怎么办
明日方舟模组数据库块是什么
网络安全行政处罚告知书
大学生网络安全精英赛比赛内容
北京云冠润通网络技术
智能网络技术做什么的
网络安全常识性知识
数据库表改名sql语句
柯美6501连接不了服务器
用友t6如何指向服务器