java红包算法·返回List<Double>
来源:互联网 发布:淘宝隐藏优惠券代码 编辑:程序博客网 时间:2024/06/04 00:04
/*红包处理过程中出现0.00以后的尾数处理办法。
先获取List<Double>数据可由red(int number, double total, double min) 获取。
获取后用red_all_count(List<Double> red_all_count)可以获取总金额,进行一个对比,红包数少误差小,生成的红包数越多,误差可能越大。
*/
//测试
public static void main(String[] args) {
List<Double> ld=red(1000, 5000, 0.01);
red_all_count(ld);
}
/**
* @param red_all_count
* @return 总金额
*/
public static double red_all_count(List<Double> red_all_count){
double dou=0.0;
for (Double double1 : red_all_count) {
dou+=double1;
}
BigDecimal bg = new BigDecimal(dou);
double d3 = bg.setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
return d3;
}
/**
* @param 总份数:number* @param 总金额:total
* @param 最小金额:min
* return doubleList
*/
public static List<Double> red(int number, double total, double min) {
// 红包数
// 红包总额
double money;
// 最小红包
double max;
int i = 1;
List<Double> list = new ArrayList<Double>();
if (number == 1) {
list.add(total);
return list;
}
DecimalFormat df = new DecimalFormat("###.##");
while (i < number) {
// 保证即使一个红包是最大的了,后面剩下的红包,每个红包也不会小于最小值
max = total - min * (number - i);
int k = (int) (number - i) / 2;
// 保证最后两个人拿的红包不超出剩余红包
if (number - i <= 2) {
k = number - i;
}
// 最大的红包限定的平均线上下
max = max / k;
// 保证每个红包大于最小值,又不会大于最大值
money = (int) (min * 100 + Math.random()
* (max * 100 - min * 100 + 1));
money = (float) money / 100;
// 保留两位小数
money = Double.parseDouble(df.format(money));
if(money<0.01){
money=DoubleUtil.changeDoubleTwo(min);
}
total = (int) (total * 100 - money * 100);
total = total / 100;
System.out.println("剩余金额:"+total+",本次生成红包:"+DoubleUtil.changeDoubleTwo(money));
list.add(money);
i++;
// 最后一个人拿走剩下的红包
if (i == number) {
list.add(total);
System.out.println("剩余金额:"+total+",本次生成红包:"+DoubleUtil.changeDoubleTwo(money));
}
// 取数组中最大的一个值的索引
return list;
}
阅读全文
0 0
- java红包算法·返回List<Double>
- java 抢红包算法
- 抢红包的红包生成算法Java实现代码
- JAVA实现 简单抢红包算法,模拟真实抢红包。
- JAVA版的微信红包算法
- java实现微信红包随机算法
- Java 实现微信红包分配算法
- java实现微信红包分配算法
- Java实现红包随机分配算法
- java生成红包的简单算法
- 红包算法
- 红包算法
- 红包算法
- 红包算法
- double list
- double list
- [算法] -- php固定红包 + 随机红包算法
- Java 红包算法、限定最小和最大临界值
- jsp与el
- 排序算法(二):交换排序
- PAT——1056. 组合数的和(15)
- 关于使用dbcp1.4出现的No suitable driver异常的问题!
- Android中实现一个简单的分享功能
- java红包算法·返回List<Double>
- 2017-10-31数据库编程sql-day2笔记
- vs2015使用MinGW编译的动态库
- Go?Docker?技术人快速学习新技术
- 如何利用碎片化时间学习技术?
- K-近邻:改进约会网站的配对效果
- 导入文件的三种方式及分析web服务日志计算元素字节大小案例
- IDEA的使用
- JavaScript-作用域链