问题:如题,判断一个单链表是否存在环
分析:判断一个单链表是否存在环,问题情况分为如下
给出的算法图示
package com.newcaoguo.main.rxjavademo;
import java.util.Scanner;
public class LinkedListLoop {
static class Node {
int val;
Node next;
public Node() {
}
}
private static final Node createLinkedListNode(Scanner scanner) {
Node node = new Node();
Node p = node;
int val = scanner.nextInt();
while (val != -1) {
p.val = val;
p.next = new Node();
p = p.next;
val = scanner.nextInt();
}
return node;
}
private static final void printLinkedListNode(Node node) {
Node p = node;
while (p != null) {
System.out.print(p.val + " ");
p = p.next;
}
}
private static final boolean isExitLoop(Node node) {
Node p = node;
Node q = node.next;
while (p != q && p != null && q != null) {
p = p.next;
q = q.next.next;
if (p == q) return true;
}
return false;
}
public static void main(String[] args) {
Node firstNode = new Node();
firstNode.val = 1;
Node secondNode = new Node();
secondNode.val = 2;
firstNode.next = secondNode;
Node thirdNode = new Node();
thirdNode.val = 3;
secondNode.next = thirdNode;
Node forthNode = new Node();
forthNode.val = 4;
thirdNode.next = forthNode;
Node fifthNode = new Node();
fifthNode.val = 5;
forthNode.next = fifthNode;
fifthNode.next = null;
System.out.println("isExitLoop: " + isExitLoop(firstNode));
}
}
打开App,阅读手记