This is the java implementation of Multiply With Carry (MWC) algorithm to generate a set of random numbers. The main advantages of the MWC method are that it invokes simple computer integer arithmetic and leads to very fast generation of sequences of random numbers with immense periods. The formula it uses is, x(n) = (a*x(n-r) + c(n-1))mod n and c(n) = (a*x(n-r) + c(n-1))/n, where a is any multiplier, m is modulus, c is carry and r is initial number of seeds.
Here is the source code of the Java Program to Generate Random Numbers Using Multiply with Carry Method. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
//This is a sample program to generate a random numbers based on Multiply with carry method
import java.util.Random;
public class Multiply_With_Carry
{
public static void main(String args[])
{
int max_Sequence_Elements = 10;
Random random = new Random();
int base_b = 2000;
int multiplier_a = random.nextInt(base_b);
int r = 1;
int []c = new int[max_Sequence_Elements];
int []x = new int[max_Sequence_Elements];
c[0] = random.nextInt(multiplier_a);
x[0] = random.nextInt(base_b);
System.out.print("The random number sequence is: " + x[0]);
//generating sequence
for(int i=1; i<max_Sequence_Elements; i++)
{
x[i] = (multiplier_a*x[i-r] + c[i-1]) % base_b;
c[i] = (multiplier_a*x[i-r] + c[i-1]) / base_b;
System.out.print(" " + x[i]);
}
}
}
Output:
$ javac Multiply_With_Carry.java $ java Multiply_With_Carry The random number sequence is: 795 382 1487 260 475 1798 1347 722 1389 63
Related posts:
Spring Security Registration – Resend Verification Email
Java Program to Check for balanced parenthesis by using Stacks
Check If a File or Directory Exists in Java
Java Program to Implement Jarvis Algorithm
Java Program to Implement Queue
Java Program to Check if it is a Sparse Matrix
Java Program to Find Inverse of a Matrix
Hướng dẫn Java Design Pattern – Strategy
Một số ký tự đặc biệt trong Java
Spring Boot - Batch Service
Các kiểu dữ liệu trong java
Converting Between an Array and a Set in Java
Comparing Dates in Java
Java Program to Implement Insertion Sort
So sánh HashSet, LinkedHashSet và TreeSet trong Java
Toán tử instanceof trong java
Java Program to Implement HashTable API
How to Read a File in Java
What is Thread-Safety and How to Achieve it?
Java Stream Filter with Lambda Expression
Lập trình đa luồng với Callable và Future trong Java
Java Program to Perform Postorder Non-Recursive Traversal of a Given Binary Tree
Java Program to Implement LinkedTransferQueue API
A Guide to JUnit 5
Java Program to Check Whether it is Weakly Connected or Strongly Connected for a Directed Graph
Java Program to Represent Graph Using Linked List
Java Program to Perform Partial Key Search in a K-D Tree
Optional trong Java 8
Spring Security Login Page with React
Java Program to Represent Graph Using Incidence Matrix
Java Program to Solve any Linear Equation in One Variable
Spring MVC Async vs Spring WebFlux