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:
Interface trong Java 8 – Default method và Static method
Spring REST API + OAuth2 + Angular
Dynamic Proxies in Java
Java Program to Generate All Possible Combinations of a Given List of Numbers
Convert Hex to ASCII in Java
Apache Commons Collections SetUtils
Java Program to Check if a Given Graph Contain Hamiltonian Cycle or Not
Java Program to Solve Tower of Hanoi Problem using Stacks
Java Program to find the maximum subarray sum O(n^2) time(naive method)
RegEx for matching Date Pattern in Java
String Processing with Apache Commons Lang 3
XML-Based Injection in Spring
Introduction to the Java NIO2 File API
OAuth2.0 and Dynamic Client Registration
Spring MVC Setup with Kotlin
Guide to DelayQueue
Function trong Java 8
Java Program to Implement ConcurrentLinkedQueue API
HashSet trong Java hoạt động như thế nào?
HashMap trong Java hoạt động như thế nào?
Introduction to Eclipse Collections
Properties with Spring and Spring Boot
Hướng dẫn Java Design Pattern – Dependency Injection
Java InputStream to String
Encode a String to UTF-8 in Java
How to Read a File in Java
Hướng dẫn Java Design Pattern – Facade
Lấy ngày giờ hiện tại trong Java
Mệnh đề if-else trong java
Guide to Escaping Characters in Java RegExps
Java Program to Implement a Binary Search Tree using Linked Lists
Multipart Upload with HttpClient 4