This is a Java Program to Implement Fermat Primality Test Algorithm. Fermat Primality Test is an algorithm which is used to determine if a given number is prime or not.
Here is the source code of the Java Program to Implement Fermat Primality Test Algorithm. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
/** ** Java Program to Implement Fermat Primality Test Algorithm **/ import java.util.Scanner; import java.util.Random; /** Class FermatPrimality **/ public class FermatPrimality { /** Function to check if prime or not **/ public boolean isPrime(long n, int iteration) { /** base case **/ if (n == 0 || n == 1) return false; /** base case - 2 is prime **/ if (n == 2) return true; /** an even number other than 2 is composite **/ if (n % 2 == 0) return false; Random rand = new Random(); for (int i = 0; i < iteration; i++) { long r = Math.abs(rand.nextLong()); long a = r % (n - 1) + 1; if (modPow(a, n - 1, n) != 1) return false; } return true; } /** Function to calculate (a ^ b) % c **/ public long modPow(long a, long b, long c) { long res = 1; for (int i = 0; i < b; i++) { res *= a; res %= c; } return res % c; } /** Main function **/ public static void main (String[] args) { Scanner scan = new Scanner(System.in); System.out.println("Fermat Primality Algorithm Test\n"); /** Make an object of FermatPrimality class **/ FermatPrimality fp = new FermatPrimality(); /** Accept number **/ System.out.println("Enter number\n"); long num = scan.nextLong(); /** Accept number of iterations **/ System.out.println("\nEnter number of iterations"); int k = scan.nextInt(); /** check if prime **/ boolean prime = fp.isPrime(num, k); if (prime) System.out.println("\n"+ num +" is prime"); else System.out.println("\n"+ num +" is composite"); } }
Output:
Fermat Primality Algorithm Test Enter number 999983 Enter number of iterations 2 999983 is prime
Related posts:
Create a Custom Exception in Java
Spring Boot - Interceptor
Guava CharMatcher
Java Program to find the maximum subarray sum using Binary Search approach
Java Program to implement Bit Set
Java Program to Implement ScapeGoat Tree
Java Program to Implement Shoelace Algorithm
Java Program to Find Basis and Dimension of a Matrix
Java Program to Generate Random Hexadecimal Byte
Functional Interface trong Java 8
Initialize a HashMap in Java
Arrays.asList vs new ArrayList(Arrays.asList())
Spring Data Java 8 Support
Mockito and JUnit 5 – Using ExtendWith
Java Program to Perform Searching Using Self-Organizing Lists
Updating your Password
Spring Boot - File Handling
Prevent Cross-Site Scripting (XSS) in a Spring Application
Java Program to Implement the Schonhage-Strassen Algorithm for Multiplication of Two Numbers
Hướng dẫn Java Design Pattern – Abstract Factory
String Operations with Java Streams
Rate Limiting in Spring Cloud Netflix Zuul
Tìm hiểu cơ chế Lazy Evaluation của Stream trong Java 8
Quick Guide to Spring Controllers
Spring REST with a Zuul Proxy
Java Program to Check Whether a Weak Link i.e. Articulation Vertex Exists in a Graph
Java Program to implement Dynamic Array
Java Program to Implement IdentityHashMap API
Stack Memory and Heap Space in Java
Java Program to Create a Minimal Set of All Edges Whose Addition will Convert it to a Strongly Conne...
Java Program to Implement Disjoint Sets
Đồng bộ hóa các luồng trong Java