我是靠谱客的博主 靓丽小土豆,这篇文章主要介绍一种新的随机数获取方法,现在分享给大家,希望可以做个参考。

用随机位来获取随机数

1 输入一个seed, 随机数的范围 比如 100
2 获取他的二进制位数 128,2的7次方,7位
3 重点是如果获取随机的二进制字符串,这里采用了System.naoTime % 2 ,但是如果太快,会造成全0

代码

static void random(int seed){
         //按照seed范围截取
         char[] seedarr = Integer.toBinaryString(seed).toCharArray();

         //获得随机数
         StringBuilder radoms = new StringBuilder();
         for(int i =1; i< seedarr.length ;i++){
            long   time =  System.nanoTime() % 2 ;
            radoms.append(time);
         }


         //整合
        int res = 0  ;
        BigDecimal bigDecimal = new BigDecimal(2);

        for(int j=seedarr.length-2  ; j>=0 ; j--){
            char [] radomsstr = radoms.toString().toCharArray();
            int pow = bigDecimal.pow(seedarr.length-2-j).intValue();

            res +=  pow * Integer.valueOf( new String(  new char[] {radomsstr[j]})) ;

        }
        System.out.println("res == " +  res);


     }

发现不规律,1000的话平均值都是30左右,说明取值不均匀,for循环纳秒太快了,导致不能随机分布0,1

最后

以上就是靓丽小土豆最近收集整理的关于一种新的随机数获取方法的全部内容,更多相关一种新内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(121)

评论列表共有 0 条评论

立即
投稿
返回
顶部