当前位置: 首页 > 编程笔记 >

Java权重随机的实现方法

薛征
2023-03-14
本文向大家介绍Java权重随机的实现方法,包括了Java权重随机的实现方法的使用技巧和注意事项,需要的朋友参考一下

本文实例讲述了Java权重随机的实现方法。分享给大家供大家参考。具体分析如下:

权重随机在项目中经常用到,所以我把它抽象到一个工具类中。

一般实现随机权重有两种方式:

1. 使用一个数组存放权重对应的实际目标,比如A的权重是2,B的权重是3,那么数组长度为5, 数组前两个存放A,后三个存放B。

然后随机一个[0-数据长度)的数字,直接取数组对应下标的值就可以了。

优点:数据结构简单,算法高效,实现简单

缺点:当权重值比较大同时数据又比较多的时候,会浪费内存

2. 使用区间算法,从前到后依次叠加权重,然后随机一个[1-权重和]的数字,再用随机的权重依次减去每个元素的权重,当第一个小于等于0的元素就是我们找元素

这里实现可以借用Arrays的binarySearch方法。

完整实例代码点击此处本站下载。

贴一下代码:

WeightMeta.java:

/** 

 * 建议使用RandomUtil类创建RandomMeta对象 

 * @author wxf on 14-5-5. 

 */  

public class WeightMeta<T> {  

    private final Random ran = new Random();  

    private final T[] nodes;  

    private final int[] weights;  

    private final int maxW;  

  

    public WeightMeta(T[] nodes, int[] weights) {  

        this.nodes = nodes;  

        this.weights = weights;  

        this.maxW = weights[weights.length - 1];  

    }  

  

    /** 

     * 该方法返回权重随机对象 

     * @return 

     */  

    public T random() {  

        int index = Arrays.binarySearch(weights, ran.nextInt(maxW) + 1);  

        if (index < 0) {  

            index = -1 - index;  

        }  

        return nodes[index];  

    }  

  

    public T random(int ranInt) {  

        if (ranInt > maxW) {  

            ranInt = maxW;  

        } else if(ranInt < 0){  

            ranInt = 1;  

        } else {  

            ranInt ++;  

        }  

        int index = Arrays.binarySearch(weights, ranInt);  

        if (index < 0) {  

            index = -1 - index;  

        }  

        return nodes[index];  

    }  

  

    @Override  

    public String toString() {  

        StringBuilder l1 = new StringBuilder();  

        StringBuilder l2 = new StringBuilder("[random]\t");  

        StringBuilder l3 = new StringBuilder("[node]\t\t");  

        l1.append(this.getClass().getName()).append(":").append(this.hashCode()).append(":\n").append("[index]\t\t");  

        for (int i = 0; i < weights.length; i++) {  

            l1.append(i).append("\t");  

            l2.append(weights[i]).append("\t");  

            l3.append(nodes[i]).append("\t");  

        }  

        l1.append("\n");  

        l2.append("\n");  

        l3.append("\n");  

        return l1.append(l2).append(l3).toString();  

    }  

}

RandomUtil.java:

/** 

 * 随机工具类 

 * 

 * 使用权重的集合Map构建随机元数据对象 

 * 

 * 比如: 

 * 我们有3个url地址,他们的权重分别为1,2,3现在我们利用RandomUtil来根据权重随机获取url: 

 * 

 * <p><blockquote><pre> 

 * 

 * map.put(url1, 1); 

 * map.put(url2, 2); 

 * map.put(url3, 3); 

 * RandomMeta<String, Integer> md = RandomUtil.buildWeightMeta(map); 

 * String weightRandomUrl = md.random(); 

 * 

 * </pre></blockquote><p> 

 * 

 * @author wxf on 14-5-5. 

 */  

public class RandomUtil {  

    public static <T> WeightMeta<T> buildWeightMeta(final Map<T, Integer> weightMap) {  

        final int size = weightMap.size();  

        Object[] nodes = new Object[size];  

        int[] weights = new int[size];  

        int index = 0;  

        int weightAdder = 0;  

        for (Map.Entry<T, Integer> each : weightMap.entrySet()) {  

            nodes[index] = each.getKey();  

            weights[index++] = (weightAdder = weightAdder + each.getValue());  

        }  

        return new WeightMeta<T>((T[]) nodes, weights);  

    }  

}

希望本文所述对大家的Java程序设计有所帮助。

 类似资料:
  • 本文向大家介绍php实现按照权重随机排序数据的方法,包括了php实现按照权重随机排序数据的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了php实现按照权重随机排序数据的方法。分享给大家供大家参考。 具体实现方法如下: 希望本文所述对大家的php程序设计有所帮助。

  • 本文向大家介绍C#实现随机洗牌的方法,包括了C#实现随机洗牌的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#实现随机洗牌的方法。分享给大家供大家参考。具体实现方法如下: 希望本文所述对大家的C#程序设计有所帮助。

  • 本文向大家介绍Java中生成随机数的实现方法总结,包括了Java中生成随机数的实现方法总结的使用技巧和注意事项,需要的朋友参考一下 在实际开发工作中经常需要用到随机数。如有些系统中创建用户后会给用户一个随机的初始化密码。这个密码由于是随机的,为此往往只有用户自己知道。他们获取了这个随机密码之后,需要马上去系统中更改。这就是利用随机数的原理。总之随机数在日常开发工作中经常用到。而不同的开发语言产生随

  • 问题内容: 在Java中,给定 n个 项目,每个项目的权重为 w ,一个人如何从集合中选择机会等于 w 的随机项目? 假设每个权重是0.0到1.0的两倍,并且集合中的权重之和为1。Item.getWeight()返回Item的权重。 问题答案: Item[] items = …;

  • 问题内容: 我想从集合中选择一个随机项目,但是选择任何项目的机会应与相关的权重成比例 输入示例: 因此,如果我有4种可能的物品,那么没有重量的任何一件物品的机会将是四分之一。 在这种情况下,用户遭受痛苦之剑的可能性应该是三刃剑的十倍。 如何在Java中进行加权随机选择? 问题答案: Apache Commons中现在有一个用于此的类: 这里是,像(假设Item接口阿恩的答案): 或在Java 8中

  • 本文向大家介绍JavaScript实现随机替换图片的方法,包括了JavaScript实现随机替换图片的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JavaScript实现随机替换图片的方法。分享给大家供大家参考。具体如下: 下面代码可实现将页面上的图片随机替换成别的图片,或者随机显示一个图片 其中的图片文件名为: 0.gif 1.gif 2.gif 3.gif 4.gif 希望本文