【www.bbyears.com--微信】
java简单模拟微信抢红包功能,本例发100元红包,有10个人抢,为了尽可能的公平,每个人的红包金额都要随机(保证结果的不确定性,本例抢红包的次序与红包金额匹配也随机),就是不能出现部分红包偏大部分偏小的情况,在区间0~100上随机生成9个节点,加0和100共11个节点按从小到大排序,各节点之间的差值就是红包金额,保证了红包金额之和等于100。
代码如下publicstaticvoidmain(String[] args)
{
// 发100元红包,10人抢
// TODO Auto-generated method stub
// 发红包总金额100元
doubleS =100;
// 0-100之间9个节点,加首尾11个点赋值给数组a
double[] a =newdouble[11];
// 第一个数是0
a[0] =0;
// 最后一个数是100
a[a.length -1] = S;
// 生成9个数随机节点并保留两位小数
for(intm =1; m < a.length -1; m++)
{
a[m] = Double.valueOf(String.format("%.2f", S * Math.random()));
}
// 冒泡排序对9个点进行排序
for(inti =1; i < a.length -2; i++)
{
for(intj =1; j < a.length -1- i; j++)
{
if(a[j] > a[j +1])
{
doubletemp;
temp = a[j];
a[j] = a[j +1];
a[j +1] = temp;
}
}
}
//红包金额赋值给数组aa
double[] aa =newdouble[a.length -1];
// 后一项减前一项的差值为红包金额
for(intn =0; n < a.length -1; n++)
{
doublemon = a[n +1] - a[n];
//用自己的算法实现四舍五入保留两位小数
intn1 = (int) (mon *1000);
intc = n1 %10;
if(c >4)
mon = (double) ((n1 +10) /10) /100;
else
mon = (double) (n1 /10) /100;
aa[n] = mon;
}
//列表打乱数组aa中的顺序,实现抢红包的次序与红包金额匹配随机
List
for(inti =0; i < aa.length; i++)
{
list.add(aa[i]);
}
Collections.shuffle(list);
for(doublei:list)
System.out.println(i);
}