这篇文章主要介绍“Java怎么确定一个链表有环及入口节点”,在日常操作中,相信很多人在Java怎么确定一个链表有环及入口节点问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java怎么确定一个链表有环及入口节点”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
我们提供的服务有:成都网站设计、网站建设、微信公众号开发、网站优化、网站认证、温岭ssl等。为近1000家企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的温岭网站制作公司
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; }
如果存在,则返回这个节点,如果不存在则返回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; }
先让快指针先走环的节点的个数步,在让慢指针开始走,如果两个指针相遇的话,那么相遇的节点必然是环的入口节点 代码如下:
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函数测试;
ublic 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怎么确定一个链表有环及入口节点”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!
分享文章:Java怎么确定一个链表有环及入口节点
标题网址:http://www.cdkjz.cn/article/jhpsjc.html