This is a Java Program to Implement Brent Cycle Algorithm. Cycle detection is the algorithmic problem of finding a cycle in a sequence of iterated function values. Brent Cycle Algorithm is an alternative cycle detection algorithm that, like the tortoise and hare algorithm, requires only two pointers into the sequence.
Here is the source code of the Java Program to Implement Brent 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 Brent Cycle Algorithm
**/
import java.util.Scanner;
import java.util.List;
import java.util.ArrayList;
/** Class BrentCycle **/
public class BrentCycle
{
private List<Integer> func;
private int lam, mu;
/** Constructor **/
public BrentCycle(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 power, lam;
power = lam = 1;
int tortoise = x0;
int hare = f(x0);
while (tortoise != hare)
{
if (power == lam)
{
tortoise = hare;
power *= 2;
lam = 0;
}
hare = f(hare);
lam += 1;
}
mu = 0;
tortoise = hare = x0;
for (int i = 0; i < lam; i++)
{
hare = f(hare);
}
while (tortoise != hare)
{
tortoise = f(tortoise);
hare = f(hare);
mu += 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("Brent 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();
BrentCycle bc = new BrentCycle(list, x0);
}
}
Brent Cycle Algorithm Test Enter size of list 9 Enter f(x) 6 6 0 1 4 3 3 4 2 Enter x0 8 First 9 elements in sequence : 8 2 0 6 3 1 6 3 1 6 Length of cycle : 3 Position : 4
Related posts:
Java Program to Check whether Graph is Biconnected
How to Return 404 with Spring WebFlux
Hướng dẫn Java Design Pattern – Adapter
New Features in Java 14
Java Program to Implement Floyd Cycle Algorithm
Introduction to Spring Cloud OpenFeign
Zipping Collections in Java
Giới thiệu Google Guice – Binding
Request a Delivery / Read Receipt in Javamail
Apache Commons Collections BidiMap
Hướng dẫn sử dụng Java Generics
Spring MVC Tutorial
HttpClient Basic Authentication
Jackson vs Gson
An Intro to Spring Cloud Security
A Guide to @RepeatedTest in Junit 5
Testing in Spring Boot
Circular Dependencies in Spring
Guide to Java Instrumentation
Java – Convert File to InputStream
Java Program to Find Shortest Path Between All Vertices Using Floyd-Warshall’s Algorithm
Overflow and Underflow in Java
Spring – Injecting Collections
Spring Boot - Batch Service
Serialization và Deserialization trong java
Spring REST API + OAuth2 + Angular
Immutable Map Implementations in Java
Java Byte Array to InputStream
Kết hợp Java Reflection và Java Annotations
Introduction to Spring Cloud CLI
Java Program to Use Boruvka’s Algorithm to Find the Minimum Spanning Tree
Filtering a Stream of Optionals in Java