阶梯级收费算法

/**
	 * 功能描述:阶梯计算奖金,具体规则可以直接在变量levels变更
	 * @author:link
	 * @param basePrize 总奖金数
	 * @return BigDecimal 根据阶梯计算后的奖金数
	 * 2016年10月21日 下午2:50:45
	 */
	public BigDecimal rewardCaculate(BigDecimal basePrize){
		BigDecimal fullPrize=new BigDecimal(0);
		if(basePrize.compareTo(levels[0])<1) return fullPrize;
		for(int i=2;i<levels.length;i+=2){
			//如果已经小于指定阶梯的界限点,则表示已经到顶了
			if(basePrize.compareTo(levels[i])<1){
				fullPrize=fullPrize.add(basePrize.subtract(levels[i-2]).multiply(levels[i+1]));
				break;
			}else{
				fullPrize=fullPrize.add(levels[i].subtract(levels[i-2]).multiply(levels[i+1]));
			}
		}
		return fullPrize;
	}
	
	private BigDecimal[] levels=new BigDecimal[]{
			new BigDecimal(3_5000d),new BigDecimal(0.0),
			new BigDecimal(5_0000d),new BigDecimal(0.1),
			new BigDecimal(10_0000d),new BigDecimal(0.15),
			new BigDecimal(15_0000d),new BigDecimal(0.2),
			new BigDecimal(20_0000d),new BigDecimal(0.25),
			new BigDecimal(25_0000d),new BigDecimal(0.3),
			new BigDecimal(30_0000d),new BigDecimal(0.35),
			new BigDecimal(35_0000d),new BigDecimal(0.4),
			new BigDecimal(40_0000d),new BigDecimal(0.45),
			new BigDecimal(45_0000d),new BigDecimal(0.5),
			new BigDecimal(50_0000d),new BigDecimal(0.5),
			new BigDecimal(60_0000d),new BigDecimal(0.5)
	};

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值