概述
用随机位来获取随机数
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
最后
以上就是靓丽小土豆为你收集整理的一种新的随机数获取方法的全部内容,希望文章能够帮你解决一种新的随机数获取方法所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复