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 5 WebClient
Spring MVC Content Negotiation
How to Change the Default Port in Spring Boot
Java Program to Implement Treap
Spring 5 Testing with @EnabledIf Annotation
Assertions in JUnit 4 and JUnit 5
Spring AMQP in Reactive Applications
Spring Boot Integration Testing with Embedded MongoDB
Introduction to Eclipse Collections
Object Type Casting in Java
Spring Web Annotations
Java Program to Solve a Matching Problem for a Given Specific Case
Hướng dẫn Java Design Pattern – Proxy
Java Program to Implement Radix Sort
Java Program to Implement AVL Tree
List Interface trong Java
Dynamic Proxies in Java
SOAP Web service: Authentication trong JAX-WS
Lập trình đa luồng trong Java (Java Multi-threading)
How to use the Spring FactoryBean?
Java InputStream to String
New Features in Java 8
Implementing a Binary Tree in Java
Tips for dealing with HTTP-related problems
ExecutorService – Waiting for Threads to Finish
Java Program to Check for balanced parenthesis by using Stacks
Hướng dẫn Java Design Pattern – Builder
Spring Security Logout
Tiêu chuẩn coding trong Java (Coding Standards)
The DAO with JPA and Spring
Netflix Archaius with Various Database Configurations
Java List UnsupportedOperationException