java简单模拟微信抢红包功能,本例发100元红包,有10个人抢,为了尽可能的公平,每个人的红包金额都要随机(保证结果的不确定性,本例抢红包的次序与红包金额匹配也随机),就是不能出现部分红包偏大部分偏小的情况,在区间0~100上随机生成9个节点,加0和100共11个节点按从小到大排序,各节点之间的差值就是红包金额,保证了红包金额之和等于100。
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); }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持亿速云。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。