Detect a loop in cyclic/circular linked list
Logic :
- If a linked list has a cycle then no node has a
null
as next pointer. - A simple loop exists when
p1.next.next !== null
as shown below.
p1
increments one node at a time and the p2
increments two points at a time. If both the pointers meet then the loop exists. If there is no loop then
p1
andp2
can not meet asp2
is in the future, we have not invented time travel yet :)
Watch the following video to understand the Floyd's cycle-finding algorithm!
This post is a follow-up of JavaScript Linked List Example. I recommend reading those posts first, as the following code uses the method from it.
Solution :
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
'use strict'; | |
function LinkedList () { | |
this.head = null; | |
} | |
LinkedList.prototype.hasLoop = function () { | |
var p1, p2; | |
p1 = this.head; | |
p2 = this.head; | |
// basic condition for loop to exist | |
while (p2.next.next) { | |
// console.log('P1 = %d, P2 = %d', p1.data, p2.data); | |
p1 = p1.next; | |
p2 = p2.next.next; | |
if (p1 == p2) { | |
return true; | |
} | |
} | |
return false; | |
}; | |
var L1 = new LinkedList(); | |
var testData = [1,2,3,4,5,6]; | |
testData.forEach(el => L1.insertNodeAtTail(el)); | |
// Create a circular linked list | |
L1.head.next.next.next.next.next.next = L1.head.next.next; | |
console.log(L1.hasLoop()); // true | |
// Remove circular dependency | |
L1.head.next.next.next.next.next.next = null; | |
console.log(L1.hasLoop()); // false | |