This is a Java Program to Implement Floyd Cycle Algorithm. Cycle detection is the algorithmic problem of finding a cycle in a sequence of iterated function values. Floyd’s cycle-finding algorithm, also called the “tortoise and the hare” algorithm, is a pointer algorithm that uses only two pointers, which move through the sequence at different speeds.
Here is the source code of the Java Program to Implement Floyd Cycle Algorithm . The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
/**
** Java Program to Implement Floyd Cycle Algorithm
**/
import java.util.Scanner;
import java.util.List;
import java.util.ArrayList;
/** Class FloydCycle **/
public class FloydCycle
{
private List<Integer> func;
private int lam, mu;
/** Constructor **/
public FloydCycle(List<Integer> list, int x0)
{
func = list;
/** print sequence **/
printSequence(x0);
/** find cycle **/
findCycle(x0);
/** display results **/
display();
}
/** function to find cycle **/
private void findCycle(int x0)
{
int tortoise = f(x0);
int hare = f(f(x0));
while (tortoise != hare)
{
tortoise = f(tortoise);
hare = f(f(hare));
}
int mu = 0;
tortoise = x0;
while (tortoise != hare)
{
tortoise = f(tortoise);
hare = f(hare);
mu += 1;
}
int lam = 1;
hare = f(tortoise);
while (tortoise != hare)
{
hare = f(hare);
lam += 1;
}
this.lam = lam;
this.mu = mu;
}
/** function to return value of function f(x) **/
private int f(int p)
{
return func.get(p);
}
/** function to print first n sequence **/
public void printSequence(int x0)
{
int n = func.size();
int tempx = x0;
System.out.print("\nFirst "+ n +" elements in sequence : \n"+ tempx);
for (int i = 0; i < n; i++)
{
tempx = f(tempx);
System.out.print(" "+ tempx);
}
System.out.println();
}
/** function to display results **/
public void display()
{
System.out.println("\nLength of cycle : "+ lam);
System.out.println("Position : "+ (mu + 1));
}
/** Main function **/
public static void main(String[] args)
{
Scanner scan = new Scanner(System.in);
System.out.println("Floyd Cycle Algorithm Test\n");
System.out.println("Enter size of list");
int n = scan.nextInt();
List<Integer> list = new ArrayList<Integer>();
System.out.println("\nEnter f(x)");
for (int i = 0; i < n; i++)
list.add(scan.nextInt());
System.out.println("\nEnter x0");
int x0 = scan.nextInt();
FloydCycle fc = new FloydCycle(list, x0);
}
}
Floyd Cycle Algorithm Test Enter size of list 9 Enter f(x) 6 6 0 1 4 3 3 4 0 Enter x0 2 First 9 elements in sequence : 2 0 6 3 1 6 3 1 6 3 Length of cycle : 3 Position : 3
Related posts:
Java Program to Implement Red Black Tree
Convert Hex to ASCII in Java
Using a Spring Cloud App Starter
Hướng dẫn Java Design Pattern – Chain of Responsibility
Comparing Long Values in Java
Java Program to Perform Partition of an Integer in All Possible Ways
Partition a List in Java
Immutable Map Implementations in Java
Entity To DTO Conversion for a Spring REST API
Java Program to Implement ScapeGoat Tree
Java Program to Implement AttributeList API
Java Program to Generate Random Hexadecimal Byte
Jackson Annotation Examples
Java Program to Implement Dijkstra’s Algorithm using Priority Queue
Java Program to Perform Postorder Recursive Traversal of a Given Binary Tree
Java – Rename or Move a File
File Upload with Spring MVC
Java Program to Implement HashMap API
Hướng dẫn Java Design Pattern – Builder
Converting a Stack Trace to a String in Java
Convert String to Byte Array and Reverse in Java
Java Program to Check Whether a Directed Graph Contains a Eulerian Cycle
Java Program to Find kth Smallest Element by the Method of Partitioning the Array
Java Program to Perform Sorting Using B-Tree
Java Program to Implement Rope
Java Program to Implement Sorted Circularly Singly Linked List
Java – Reader to InputStream
Using Optional with Jackson
Spring Boot Annotations
Giới thiệu Java Service Provider Interface (SPI) – Tạo các ứng dụng Java dễ mở rộng
Guide to the Volatile Keyword in Java
Java Program to Find Hamiltonian Cycle in an UnWeighted Graph