Java实现双色球抽奖随机算法示例

时间:2021-05-19

第一次写技术博客,写一下以前写的一个双色球抽奖随机算法。

原理如下:

1首先初始化一个待抽奖的数组nums,数组的长度k

2. 随机一个1-k之间的随机数,得到nums【k】,这样得到第一个抽奖号,nums中剔除该号码,k--。

3. 重复步骤2,直到得到全部中奖号码

class myLuck { private int mTarget; List<Integer> mNums = new ArrayList<Integer>(); //摇奖池 ///从多少个数中产生多少个数 ///例如 33选6 则Source=33,Target=6; myLuck(int vSource,int vTarget) { for (int i = 1; i <=vSource ; i++) { mNums.add(i); } mTarget=vTarget; } public String GetNums() { String xString=""; for (int i =0;i<mTarget; i++) { int _index=(int)(Math.random()* mNums.size()); xString+=mNums.get(_index)+" "; //System.out.print("("+(_index+1)+")"+mNums.get(_index)+"-"); //如何删除一个元素 mNums.remove(_index); } return xString; } }

调用方式如下:

myLuck _red=new myLuck(33, 6); myLuck _blue=new myLuck(16,1);String Str =_red.GetNums() +","+_blue.GetNums();

很简单,将结果输出即可~

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章