C语言实例_3之分段计算加成

1. 题目

玩游戏时,当攻击力高于某一阶段时,会获得额外战斗力加成,当然攻击力越高,提升越少,不然就破坏游戏平衡了。
规则如下:
规则1:攻击力低于或等于10万时,战斗力额外可提升10%;
规则2:攻击力高于10万,低于20万时,低于10万的部分按规则1,高于10万的部分,战斗力额外可提升7.5%;
规则3:20万到40万之间时,低于20万的部分按规则2,高于20万的部分,战斗力额外可提升5%;
规则4:40万到60万之间时,低于40万的部分按规则3,高于40万的部分,战斗力额外可提升3%;
规则5:60万到100万之间时,低于60万的部分按规则4,高于60万的部分,战斗力额外可提升1.5%;
规则6:高于100万时,低于100万的部分按规则5,高于100万的部分,战斗力额外可提升1%.
玩家可从键盘输入角色攻击力,求额外战斗力加成是多少?

2. 分析

这需要根据规则进行分段计算。

3. 实例代码之if计算

#include <stdio.h>int main() {double attackPower;double extraBonus = 0;// 从键盘输入角色攻击力printf("请输入角色的攻击力:");scanf("%lf", &attackPower);if (attackPower <= 100000) {extraBonus = attackPower * 0.1;} else if (attackPower > 100000 && attackPower < 200000) {extraBonus = 100000 * 0.1 + (attackPower - 100000) * 0.075;} else if (attackPower >= 200000 && attackPower < 400000) {extraBonus = 100000 * 0.1 + 100000 * 0.075 + (attackPower - 200000) * 0.05;} else if (attackPower >= 400000 && attackPower < 600000) {extraBonus = 100000 * 0.1 + 100000 * 0.075 + 200000 * 0.05 + (attackPower - 400000) * 0.03;} else if (attackPower >= 600000 && attackPower < 1000000) {extraBonus = 100000 * 0.1 + 100000 * 0.075 + 200000 * 0.05 + 200000 * 0.03 + (attackPower - 600000) * 0.015;} else if (attackPower >= 1000000) {extraBonus = 100000 * 0.1 + 100000 * 0.075 + 200000 * 0.05 + 200000 * 0.03 + 400000 * 0.015 + (attackPower - 1000000) * 0.01;}printf("额外战斗力加成是:%lf\n", extraBonus);return 0;
}

以上代码就是根据业务,硬编程,便于理解。
以下是使用switch实现

4. 实例代码之switch计算

#include <stdio.h>int main() {double attackPower;double extraBonus = 0;// 从键盘输入角色攻击力printf("请输入角色的攻击力:");scanf("%lf", &attackPower);// 根据攻击力范围确定初始区间索引int intervalIndex;if (attackPower <= 100000) {intervalIndex = 1;} else if (attackPower <= 200000) {intervalIndex = 2;} else if (attackPower <= 400000) {intervalIndex = 3;} else if (attackPower <= 600000) {intervalIndex = 4;} else if (attackPower <= 1000000) {intervalIndex = 5;} else {intervalIndex = 6;}switch (intervalIndex) {case 1:extraBonus = attackPower * 0.1;break;case 2:extraBonus = 100000 * 0.1 + (attackPower - 100000) * 0.075;break;case 3:extraBonus = 100000 * 0.1 + 100000 * 0.075 + (attackPower - 200000) * 0.05;break;case 4:extraBonus = 100000 * 0.1 + 100000 * 0.075 + 200000 * 0.05 + (attackPower - 400000) * 0.03;break;case 5:extraBonus = 100000 * 0.1 + 100000 * 0.075 + 200000 * 0.05 + 200000 * 0.03 + (attackPower - 600000) * 0.015;break;case 6:extraBonus = 100000 * 0.1 + 100000 * 0.075 + 200000 * 0.05 + 200000 * 0.03 + 400000 * 0.015 + (attackPower - 1000000) * 0.01;break;default:printf("输入有误,请重新输入有效攻击力值。\n");break;}printf("额外战斗力加成是:%lf\n", extraBonus);return 0;
}

这个和if计算类似。

5. 实例代码之switch穿透现象计算

#include <stdio.h>int main() {double attackPower;double extraBonus = 0.0;int nBaseNo = 100000;// 从键盘输入角色攻击力printf("请输入角色的攻击力:");scanf("%lf", &attackPower);int nFlag;nFlag = (int)(attackPower / nBaseNo);nFlag = nFlag > 10 ? 10 : nFlag;switch (nFlag) {case 10:extraBonus += (attackPower - 10 * nBaseNo) * 0.01;attackPower = 10 * nBaseNo;case 9:case 8:case 7:case 6:extraBonus += (attackPower - 6 * nBaseNo) * 0.015;attackPower = 6 * nBaseNo;case 5:case 4:extraBonus += (attackPower - 4 * nBaseNo) * 0.03;attackPower = 4 * nBaseNo;case 3:case 2:extraBonus += (attackPower - 2 * nBaseNo) * 0.05;attackPower = 2 * nBaseNo;case 1:extraBonus += (attackPower - nBaseNo) * 0.075;attackPower = nBaseNo;case 0:extraBonus += attackPower * 0.1;}printf("额外战斗力加成是:%lf\n", extraBonus);return 0;
}

除此之外,还可以使用 数组、递归、链表等方式实现。主要是分析方式,实现就多了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/887191.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SSM全家桶 1.Maven

或许总要彻彻底底地绝望一次 才能重新再活一次 —— 24.11.20 maven在如今的idea中已经实现自动配置&#xff0c;不需要我们手动下载 一、Maven的简介和快速入门 Maven 是一款为 Java 项目构建管理、依赖管理的工具(软件)&#xff0c;使用 Maven 可以自动化构建测试、打包和发…

Oracle SQL*Plus中的SET VERIFY

在 Oracle SQL*Plus 中&#xff0c;SET VERIFY ON 和 SET VERIFY OFF 是两个用于控制命令执行前后显示变量值的命令。这些命令主要用于调试和验证 SQL 脚本中的变量替换情况。 一、参数说明 1.1 SET VERIFY ON 作用&#xff1a;启用变量替换的验证功能。当启用时&#xff0c;S…

双因子认证:统一运维平台安全管理策略

01双因子认证概述 双因子认证&#xff08;Two-Factor Authentication&#xff0c;简称2FA&#xff09;是一种身份验证机制&#xff0c;它要求用户提供两种不同类型的证据来证明自己的身份。这通常包括用户所知道的&#xff08;如密码&#xff09;、用户所拥有的&#xff08;如…

【Unity ShaderGraph实现流体效果之Function入门】

Unity ShaderGraph实现流体效果之Node入门&#xff08;一&#xff09; 前言Shader Graph NodePosition NodeSplit NodeSubtract NodeBranch Node 总结 前言 Unity 提供的Shader Graph在很大程度上简化了开发者对于编写Shader的工作&#xff0c;只需要拖拽即可完成一个视觉效果…

力扣—15.三数之和

15. 三数之和 给你一个整数数组 nums &#xff0c;判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i ! j、i ! k 且 j ! k &#xff0c;同时还满足 nums[i] nums[j] nums[k] 0 。请你返回所有和为 0 且不重复的三元组。 注意&#xff1a;答案中不可以包含重复的三元…

Java项目实战II基于SpringBoot前后端分离的网吧管理系统(开发文档+数据库+源码)

目录 一、前言 二、技术介绍 三、系统实现 四、核心代码 五、源码获取 全栈码农以及毕业设计实战开发&#xff0c;CSDN平台Java领域新星创作者&#xff0c;专注于大学生项目实战开发、讲解和毕业答疑辅导。获取源码联系方式请查看文末 一、前言 随着互联网技术的不断发展…

【设计模式系列】责任链模式(十六)

一、什么是责任链模式 责任链模式&#xff08;Chain of Responsibility Pattern&#xff09;是一种行为型设计模式。其核心思想是将请求的发送者和接收者解耦&#xff0c;通过一个中介链来传递请求&#xff0c;使得多个对象都有可能接收请求&#xff0c;从而避免请求发送者和接…

算法学习笔记(十):位运算、数论等

一.位运算基础 集合与集合之间的位运算 集合和元素 常用函数 1.使两个整数相等的位更改次数 给你两个正帧数 n 和 k&#xff0c;你可以选择 n 的二进制表示 中任意一个值为 1 的位&#xff0c; 并将其改为0&#xff0c;返回使得 n 等于 k 所需要的更改次数&#xff0c;如无法实…

恋爱通信史之完整性

在前面的章节中&#xff0c;介绍了对通信消息的加密&#xff0c;可以保证保密性(机密性)。虽说中间人无法解密通信消息的内容&#xff0c;但是可以篡改通信的消息。在接受者视角来看&#xff0c;是无法识别通信消息是否被篡改。因此&#xff0c;必须引入一种机制&#xff0c;保…

数据结构第一讲

数据结构定义 算法的定义 什么是好算法&#xff1f; 空间复杂度 时间复杂度 例子1 打印1到N之间的正整数 有递归和循环两种方法实现。 但是在数字变大后&#xff0c;递归的方法会导致内存占用过多而崩溃。 而循环则不会 例子2 写程序给定多项式在X处的值 从里往外算的算…

安卓应用安装过程学习

声明&#xff1a;此文章来自http://shuwoom.com/?p60的学习记录 启动式安装 public static final IPackageManager main(Context context, Installer installer,boolean factoryTest, boolean onlyCore) {PackageManagerService m new PackageManagerService(context, inst…

输入/输出管理 III(磁盘和固态硬盘)

一、磁盘 【总结】&#xff1a; 磁盘&#xff08;Disk&#xff09;是由表面涂有磁性物质的物理盘片&#xff0c;通过一个称为磁头的导体线圈从磁盘存取数据。在读&#xff0f;写操作期间&#xff0c;磁头固定&#xff0c;磁盘在下面高速旋转。如下图所示&#xff1a; 磁盘盘面…

使用flink编写WordCount

1. env-准备环境 2. source-加载数据 3. transformation-数据处理转换 4. sink-数据输出 5. execute-执行 流程图&#xff1a; DataStream API开发 //nightlies.apache.org/flink/flink-docs-release-1.13/docs/dev/datastream/overview/ 添加依赖 <properties>&l…

# issue 4 进程控制函数

目录 一、进程控制函数一 二、进程控制函数二 启动进程&#xff1a;&#xff08;exec系列&#xff09; 创建新进程&#xff1a; 测试代码&#xff1a; 测试结果&#xff1a; 三、进程控制函数三 结束进程&#xff1a; 测试代码&#xff1a; 测试结果&#xff1a; 四、…

Java项目实战II基于SpringBoot的共享单车管理系统开发文档+数据库+源码)

目录 一、前言 二、技术介绍 三、系统实现 四、核心代码 五、源码获取 全栈码农以及毕业设计实战开发&#xff0c;CSDN平台Java领域新星创作者&#xff0c;专注于大学生项目实战开发、讲解和毕业答疑辅导。获取源码联系方式请查看文末 一、前言 在共享经济蓬勃发展的今天…

Linux 网络编程之UDP套接字

前言 前面我们对网络的发展&#xff0c;网络的协议、网路传输的流程做了介绍&#xff0c;最后&#xff0c;我们还介绍了 IP 和 端口号&#xff0c;ip port 叫做 套接字 socket&#xff0c; 本期我们就来介绍UDP套接字编程&#xff01; 目录 1、预备知识 1.1 传输层协议: T…

---Arrays类

一 java 1.Arrays类 1.1 toString&#xff08;&#xff09; 1.2 arrays.sort( )-----sort排序 1&#xff09;直接调用sort&#xff08;&#xff09; Arrays.sort() 方法的默认排序顺序是 从小到大&#xff08;升序&#xff09;。 2&#xff09;定制排序【具体使用时 调整正负…

Java 对象头、Mark Word、monitor与synchronized关联关系以及synchronized锁优化

1. 对象在内存中的布局分为三块区域&#xff1a; &#xff08;1&#xff09;对象头&#xff08;Mark Word、元数据指针和数组长度&#xff09; 对象头&#xff1a;在32位虚拟机中&#xff0c;1个机器码等于4字节&#xff0c;也就是32bit&#xff0c;在64位虚拟机中&#xff0…

6.7机器学习期末复习题

空间 样本空间 就是属性的所有可能情况&#xff0c;包括了一切可能出现或不可能出现的所有样本情况 版本空间&假设空间 假设空间就是在样本空间的基础上&#xff0c;给所有属性都加了一个通配符&#xff0c;表示任意即可&#xff1b;以及加上了一个空集&#xff0c;表示…

Qt界面设计时使各控件依据窗口缩放进行栅格布局的方法

图1 最终效果 想要达成上述图片的布局效果&#xff0c;具体操作如下&#xff1a; 新建一窗体&#xff1a; 所需控件如下&#xff1a; Table View控件一个&#xff1b; Group Box控件一个&#xff1b; Push Button控件2个&#xff1b; Horiziontal Spacer控件2个&#xf…