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:
Java Program to Check Whether a Directed Graph Contains a Eulerian Path
Lập trình đa luồng với CompletableFuture trong Java 8
Java Program to Generate Randomized Sequence of Given Range of Numbers
Java Program to Compute Determinant of a Matrix
Java Program to Represent Graph Using Incidence Matrix
Introduction to Apache Commons Text
Constructor Injection in Spring with Lombok
Spring Boot - Tomcat Port Number
Java Program to Implement Hash Tables with Double Hashing
Apache Commons Collections MapUtils
Spring Boot - Quick Start
LinkedList trong java
Java Program to Compute DFT Coefficients Directly
Spring Boot Configuration with Jasypt
Java Program to Generate Random Numbers Using Middle Square Method
How to Use if/else Logic in Java 8 Streams
Converting String to Stream of chars
Java Program to Generate Date Between Given Range
Introduction to Spring Data JDBC
A Comparison Between Spring and Spring Boot
Show Hibernate/JPA SQL Statements from Spring Boot
Spring Boot - Rest Template
Spring Webflux with Kotlin
Java Program to Implement Meldable Heap
Shuffling Collections In Java
Java Program to Implement Pagoda
Java Program to Check Cycle in a Graph using Topological Sort
Prevent Brute Force Authentication Attempts with Spring Security
Chuyển đổi từ HashMap sang ArrayList
Java Program to find the number of occurrences of a given number using Binary Search approach
Java Program to Generate N Number of Passwords of Length M Each
Handling URL Encoded Form Data in Spring REST