Generating Random Numbers with Weights in Java

Random number generation with weighted probabilities is a common requirement in various programming scenarios, such as game development, statistical sampling, and machine learning algorithms. Java provides several approaches to accomplish this task efficiently.

in this tutorial To generate random values with weights in Java, you can use a weighted random selection technique. Here’s a simple example:

Here is the Example

import java.util.HashMap;
import java.util.Map;
import java.util.Random;


public class Ex1 {
    public static void main(String[] args) {
        // Define items and their weights
        Map<String, Integer> items = new HashMap<>();
        items.put("Apple", 5);   // Weight for Apple
        items.put("Banana", 1);  // Weight for Banana
        items.put("Cherry", 3);  // Weight for Cherry

        // Generate weighted random selections
        for (int i = 0; i < 10; i++) {
            String randomItem = getRandomItem(items);
            System.out.println(randomItem);
        }
    }

    public static String getRandomItem(Map<String, Integer> items) {
        // Calculate the total weight
        int totalWeight = items.values().stream().mapToInt(Integer::intValue).sum();

        // Generate a random number in the range of 0 to totalWeight
        int randomValue = new Random().nextInt(totalWeight);

        // Iterate through the items and subtract weights to find the selected item
        for (Map.Entry<String, Integer> entry : items.entrySet()) {
            randomValue -= entry.getValue();
            if (randomValue < 0) {
                return entry.getKey();
            }
        }

        throw new RuntimeException("Should never reach here if weights are correctly defined.");
    }
}
  • Weights: Each item is assigned a weight. Higher weights mean the item is more likely to be selected.
  • Total Weight: Sum of all weights is calculated.
  • Random Value: A random number is generated between 0 and the total weight.
  • Selection: The method iterates through the items and subtracts their weights from the random value until it finds the selected item.

 

admin

Share
Published by
admin
Tags: java

Recent Posts

Java Beans

A Java Bean is a reusable software component that follows a specific set of conventions.…

2 hours ago

Java String Methods

Java provides a rich set of built-in methods for handling String operations efficiently. Since strings…

2 hours ago

Java Developer Jobs

Java remains one of the most in-demand programming languages worldwide, powering everything from enterprise applications…

3 hours ago

Converting Integer to String in Java

Java provides multiple ways to convert an integer (int) to a string (String). Whether you're…

3 hours ago

JSP to JSP Communication: A Complete Guide to Dynamic Java Web Development

Java Server Pages (JSP) is a powerful technology used to develop dynamic web applications by…

5 days ago

Which Frontend Framework to Use with Spring Boot?

Spring Boot is a powerful backend framework for developing Java-based web applications. Pairing it with…

6 days ago