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:
New Features in Java 15
Java Program to Implement Bresenham Line Algorithm
Comparing Strings in Java
Using a List of Values in a JdbcTemplate IN Clause
Toán tử instanceof trong java
Java Program to Find Median of Elements where Elements are Stored in 2 Different Arrays
Java Program to Perform String Matching Using String Library
Java Program to Represent Graph Using Linked List
Java Program to Find Basis and Dimension of a Matrix
Java Program to Implement ConcurrentSkipListMap API
Java Program to Implement Adjacency Matrix
XML Serialization and Deserialization with Jackson
Spring Boot - Enabling Swagger2
Hướng dẫn Java Design Pattern – MVC
Java Program to Implement LinkedHashMap API
Dynamic Proxies in Java
Java Program to Use Boruvka’s Algorithm to Find the Minimum Spanning Tree
Spring Boot - Web Socket
Using JWT with Spring Security OAuth
Request a Delivery / Read Receipt in Javamail
Introduction to Spring Data JDBC
Bootstrapping Hibernate 5 with Spring
Java Program to Implement Self Balancing Binary Search Tree
Guide to the Synchronized Keyword in Java
The Guide to RestTemplate
Java Program to Implement Sparse Matrix
Hướng dẫn Java Design Pattern – Factory Method
Java Program to Implement Double Ended Queue
Spring Boot Application as a Service
Guide to CountDownLatch in Java
Spring Security – Reset Your Password
Biến trong java