This is a Java Program to Implement Solovay Strassen Primality Test Algorithm. Solovay Strassen 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 Solovay Strassen 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 SolovayStrassen Primality Test Algorithm
**/
import java.util.Scanner;
import java.util.Random;
/** Class SolovayStrassen **/
public class SolovayStrassen
{
/** Function to calculate jacobi (a/b) **/
public long Jacobi(long a, long b)
{
if (b <= 0 || b % 2 == 0)
return 0;
long j = 1L;
if (a < 0)
{
a = -a;
if (b % 4 == 3)
j = -j;
}
while (a != 0)
{
while (a % 2 == 0)
{
a /= 2;
if (b % 8 == 3 || b % 8 == 5)
j = -j;
}
long temp = a;
a = b;
b = temp;
if (a % 4 == 3 && b % 4 == 3)
j = -j;
a %= b;
}
if (b == 1)
return j;
return 0;
}
/** 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;
long jacobian = (n + Jacobi(a, n)) % n;
long mod = modPow(a, (n - 1)/2, n);
if(jacobian == 0 || mod != jacobian)
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("SolovayStrassen Primality Algorithm Test\n");
/** Make an object of SolovayStrassen class **/
SolovayStrassen ss = new SolovayStrassen();
/** 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 = ss.isPrime(num, k);
if (prime)
System.out.println("\n"+ num +" is prime");
else
System.out.println("\n"+ num +" is composite");
}
}
Output:
SolovayStrassen Primality Algorithm Test Enter number 9997777 Enter number of iterations 1 9997777 is prime
Related posts:
Java Program to Implement Network Flow Problem
Spring Boot - Bootstrapping
Properties with Spring and Spring Boot
Tiêu chuẩn coding trong Java (Coding Standards)
Implementing a Runnable vs Extending a Thread
Java Program to Implement Trie
Spring WebClient Filters
Receive email using IMAP
Java Program to Check whether Undirected Graph is Connected using BFS
Tổng quan về ngôn ngữ lập trình java
Java Program to Represent Graph Using Adjacency List
Java Program to Solve Set Cover Problem assuming at max 2 Elements in a Subset
Java Program to Solve a Matching Problem for a Given Specific Case
Guide to UUID in Java
Java Program to Implement Heap Sort Using Library Functions
Limiting Query Results with JPA and Spring Data JPA
Using a Custom Spring MVC’s Handler Interceptor to Manage Sessions
Làm thế nào tạo instance của một class mà không gọi từ khóa new?
Display Auto-Configuration Report in Spring Boot
The Spring @Controller and @RestController Annotations
Sereja and Algorithm
Convert a Map to an Array, List or Set in Java
Spring Cloud AWS – S3
Giới thiệu về Stream API trong Java 8
Concurrent Test Execution in Spring 5
Lớp Collectors trong Java 8
Java Program to Compute DFT Coefficients Directly
Guava – Join and Split Collections
Testing in Spring Boot
Java Program to Implement Pairing Heap
Sorting Query Results with Spring Data
Java – Get Random Item/Element From a List