标签:
查找链表中是否有环路(cycle)(注:cycle,有周期的意思,所以注意这里指的是环路的意思)
public static boolean fun(linklist head)
{
boolean check=false;
ListNode p=head;
ListNode q=head;
if(p!=null) {
if (head.next != null) {
q = head.next;
while (true) {
if (p == q) {
check = true;
break;
} else if (q == null) {
break;
} else {
p = p.next;
if (q.next != null && q.next.next != null)
q = q.next.next;
else {
break;
}
}
}
}
}
return check;
}
整个的思想就是每次两个指针,第一个每次移动一个位置。第二个每次移动两个位置。如果或环路的话,最终总有一个时刻会相遇的(以为一个指针会移动了两次,一个移动一次,那么的话,相对移动了一个位置,就是每次会靠近移动慢的指针一个单位。最终的结果就是赶上了最前面的)
以下提供一种方法非常好像的东西,就是一个指针每次移动一个单位,另一个每次都遍历整个链表,如果有一个位置上出现了null 直接得出是无cycle的。如果说出现了其中的一个指针位置等于另一指针的下一个位置,就是有环路,直接退出,结束。
标签:
原文地址:http://www.cnblogs.com/qinyongzhu/p/4960411.html