当前位置:首页 > java基础 > 正文内容

按权重随机排序

淙嶙6年前 (2019-02-02)java基础2305

按权重随机排序 方案1,将list中每个实体的权重先取个随机值,然后在按随机后的权重排序。

public void sortList(List<Entity> list) {
        if(list == null){
            return;
        }
        list.forEach((Entity item) -> item.setWeight(random.nextInt(getWeight(item))));
        Collections.sort(list,(Entity item1,Entity item2) -> getWeight(item2)- getWeight(item1));
    }

        private int getWeight(Entity item) {
        Integer weight = item.getWeight();
        weight = weight==null ? 0 : weight;
        return weight;
    }

相关文章

动态代理

动态代理

一、实现动态代理的方式: jdk动态代理CGlib动态代理javassist动态代理 CGlib底层实现依赖于ASM, javassist自成一派. 由于ASM和javassist需要程序员直接操...

理解TheadLocal源码

理解TheadLocal源码

记忆会被改变,以前看过的代码,现在发现和记忆中的不一样,大脑会修改记忆的确是真的. 那就重复的看下,记录下吧. 作用: 为每个使用该变量的线程创建一个独立的变量副本.在多线程环境,就能避免变...

ConcurrentHashMap源码解读

ConcurrentHashMap源码解读

/* * Written by Doug Lea with assistance from members of JCP JSR-166 * Expert Group and released...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。