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 Perform Partial Key Search in a K-D Tree
HashSet trong Java hoạt động như thế nào?
Sử dụng CyclicBarrier trong Java
Converting Java Date to OffsetDateTime
Encode/Decode to/from Base64
Java Streams vs Vavr Streams
Java Program to Perform the Shaker Sort
Extract network card address
New Features in Java 14
Java – Write an InputStream to a File
Handling Errors in Spring WebFlux
HttpClient 4 – Send Custom Cookie
Disable Spring Data Auto Configuration
A Comparison Between Spring and Spring Boot
Intro to Spring Boot Starters
Java Program to Implement Selection Sort
Spring MVC and the @ModelAttribute Annotation
Refactoring Design Pattern với tính năng mới trong Java 8
Jackson Date
The DAO with JPA and Spring
Java Program to Implement Warshall Algorithm
Anonymous Classes in Java
Find the Registered Spring Security Filters
Từ khóa static và final trong java
So sánh Array và ArrayList trong Java
File Upload with Spring MVC
Java Program to Implement Sorted Array
Comparing Dates in Java
Spring Cloud Bus
Java – Try with Resources
Jackson – JsonMappingException (No serializer found for class)
Autoboxing và Unboxing trong Java