代码实现:

public class Hello {
public static void main(String srgs[]) {
Lirun(100);
Lirun2(100);
} public static double Lirun(double lirun) {
/**
* 输入lirun的单位为万元
*/
double sum = 0;
if (lirun <= 10) {
sum = lirun * 0.1; } else if (lirun > 10 && lirun <= 20) {
sum = (lirun - 10) * 0.075 + 10 * 0.1;
} else if (lirun > 20 && lirun <= 40) {
sum = (lirun - 20) * 0.05 + (20 - 10) * 0.075 + 10 * 0.1;
} else if (lirun > 40 && lirun <= 60) {
sum = (lirun - 40) * 0.03 + (40 - 20) * 0.05 + (20 - 10) * 0.075 + 10 * 0.1;
} else if (lirun > 60 && lirun <= 100) {
sum = (lirun - 60) * 0.015 + (60 - 40) * 0.03 + (40 - 20) * 0.05 + (20 - 10) * 0.075 + 10 * 0.1;
} else if (lirun > 100) {
sum = (lirun - 100) * 0.001 + (100 - 60) * 0.015 + (60 - 40) * 0.03 + (40 - 20) * 0.05 + (20 - 10) * 0.075
+ 10 * 0.1;
}
System.out.println("当前利润为:" + lirun + "万元,应得奖金为:" + sum + "万元!");
return sum;
} public static double Lirun2(double lirun) {
/**
* 输入lirun的单位为万元 定义两个double类型的数组,分别存入利润值分段和对应的奖金比例。
*/
double sum = 0;
double tmp = lirun; // 定义一个临时变量
boolean flag = false; // 定义一个flag,用来标记是否已经找到利润值表的对应元素,然后根据这个flag进行下一个阶段的奖金值计算
double[] lirunArr = { 10, 20, 40, 60, 100 };
double[] Arrnum = { 0.1, 0.075, 0.05, 0.03, 0.015 };
for (int i = lirunArr.length - 1; i >= 0; i--) { // 遍历利润值
if (tmp > lirunArr[i]) { // 判断当前的临时变量(输入的利润值)是否大于利润值表的最大元素,目的找到输入的利润值的取值范围
tmp = tmp - lirunArr[i];
sum += tmp * Arrnum[i];
flag = true;
} else if (flag && i >= 1) { // 按照利润值表中各阶段对应的奖金比例计算奖金。
tmp = lirunArr[i] - lirunArr[i - 1];
sum += tmp * Arrnum[i];
} else if (i == 0) { // 理论上需要定义数组时输入一个0的元素,但是如果不定义,那就得利用i==0的特殊情况进行区别处理,以处理第二阶段数组越界的情况。
tmp = lirunArr[i];
sum += tmp * Arrnum[i];
} // System.out.println("i=" + i + ";tmp=" + tmp + ";sum=" + sum);
}
System.out.println("当前利润为:" + lirun + "万元,应得奖金为:" + sum + "万元!");
return sum;
}
}

  

最新文章

  1. Shell父进程获取子进程的变量值
  2. 菜单导航/URHere/面包屑,通过CSS中的content简洁表达代码
  3. 64位系统如何导入excel
  4. PHP 基础
  5. Android异步回调中的UI同步性问题
  6. docker-7 docker在阿里云的使用
  7. C语言中 *.c和*.h文件的区别!
  8. Hbase step by step 完全分布式安装
  9. codeforces A. Vasily the Bear and Triangle 解题报告
  10. 北大poj-1001
  11. Java多线程 -- 深入理解JMM(Java内存模型) --(五)锁
  12. 关于PreferenceActivity的使用和一些问题的解决(自己定义Title和取值)
  13. Microsoft Windows Server 2008 R2 IIS7.5安装指南
  14. linux内存操作----kernel 3.5.X copy_from_user()和copy_to_user()
  15. Mysql only_full_group_by以及其他关于sql_mode原因报错详细解决方案
  16. RaspberryPi上建立wordpress
  17. HTML5 History API &amp; URL 重定向
  18. POJ 2955 Brackets(区间DP)题解
  19. web前端开发浏览器兼容性处理大全
  20. 使用BigDecimal转换较长小数时候出现科学计数法的问题

热门文章

  1. Seafile 网络磁盘
  2. luogu P3191 [HNOI2007]紧急疏散EVACUATE
  3. saltstack系列~第一篇
  4. DSO windowed optimization 代码 (2)
  5. shiroWeb项目-认证及MD5认证信息在页面显示(十)
  6. Informatic学习总结_day01
  7. DFP算法(转载)
  8. 如何交叉编译 linux kernel 内核
  9. HTMl学习笔记02-编辑器
  10. SharePoint 2010:搜索服务当前处于脱机状态