java简单模拟微信抢红包功能,本例发100元红包,有10个人抢,为了尽可能的公平,每个人的红包金额都要随机(保证结果的不确定性,本例抢红包的次序与红包金额匹配也随机),就是不能出现部分红包偏大部分偏小的情况,在区间0~100上随机生成9个节点,加0和100共11个节点按从小到大排序,各节点之间的差值就是红包金额,保证了红包金额之和等于100。
?
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
|
public static void main(String[] args)
{
// 发100元红包,10人抢
// TODO Auto-generated method stub
// 发红包总金额100元
double S = 100;
// 0-100之间9个节点,加首尾11个点赋值给数组a
double[] a = new double[11];
// 第一个数是0
a[0] = 0;
// 最后一个数是100
a[a.length - 1] = S;
// 生成9个数随机节点并保留两位小数
for (int m = 1; m < a.length - 1; m++)
{
a[m] = Double.valueOf(String.format("%.2f", S * Math.random()));
}
// 冒泡排序对9个点进行排序
for (int i = 1; i < a.length - 2; i++)
{
for (int j = 1; j < a.length - 1 - i; j++)
{
if (a[j] > a[j + 1])
{
double temp;
temp = a[j];
a[j] = a[j + 1];
a[j + 1] = temp;
}
}
}
//红包金额赋值给数组aa
double[] aa = new double[a.length - 1];
// 后一项减前一项的差值为红包金额
for (int n = 0; n < a.length - 1; n++)
{
double mon = a[n + 1] - a[n];
//用自己的算法实现四舍五入保留两位小数
int n1 = (int) (mon * 1000);
int c = n1 % 10;
if (c > 4)
mon = (double) ((n1 + 10) / 10) / 100;
else
mon = (double) (n1 / 10) / 100;
aa[n] = mon;
}
//列表打乱数组aa中的顺序,实现抢红包的次序与红包金额匹配随机
List<Double> list = new ArrayList<>();
for(int i = 0; i < aa.length; i++)
{
list.add(aa[i]);
}
Collections.shuffle(list);
for(double i:list)
System.out.println(i);
}
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持快网idc。
原文链接:http://www.jianshu.com/p/40d70963dd89
相关文章
猜你喜欢
- 64M VPS建站:怎样选择合适的域名和SSL证书? 2025-06-10
- 64M VPS建站:怎样优化以提高网站加载速度? 2025-06-10
- 64M VPS建站:是否适合初学者操作和管理? 2025-06-10
- ASP.NET自助建站系统中的用户注册和登录功能定制方法 2025-06-10
- ASP.NET自助建站系统的域名绑定与解析教程 2025-06-10
TA的动态
- 2025-07-10 怎样使用阿里云的安全工具进行服务器漏洞扫描和修复?
- 2025-07-10 怎样使用命令行工具优化Linux云服务器的Ping性能?
- 2025-07-10 怎样使用Xshell连接华为云服务器,实现高效远程管理?
- 2025-07-10 怎样利用云服务器D盘搭建稳定、高效的网站托管环境?
- 2025-07-10 怎样使用阿里云的安全组功能来增强服务器防火墙的安全性?
快网idc优惠网
QQ交流群
您的支持,是我们最大的动力!
热门文章
-
IntelliJ IDEA maven 构建简单springmvc项目(图文教程)
2025-05-29 50 -
2025-05-29 72
-
2025-05-29 76
-
2025-05-25 91
-
2025-06-05 25
热门评论

