解题思路:根据题目描述来写,由于不知道具体要循环几组,所以用到while循环

注意事项:初始体力值是0,雇佣兵必须要先用能量元素恢复体力再进行战斗,所以能量消耗程序和战斗值增加程序不要颠倒顺序

然后再判断剩下的能量够不够去消耗,不够就退出循环,够就继续循环。

最后计算战斗值,然后累加后输出最大战斗值。

参考代码:

#include <stdio.h>

int main() {

    int M,N,X;

    scanf("%d %d %d",&M,&N,&X);

    int tili = M;

    int nengliang = X;

    int jingyan_now = N;

    int jingyan_gain;

    int jingyan = 0;

    int cost_nengliang;

    while(1) {

        cost_nengliang = (M+jingyan_now-1)/jingyan_now;//向上取整计算能量消耗

        if(nengliang<cost_nengliang)//判断能量够不够消耗

        {

            break;

        } else

        {

            nengliang -= cost_nengliang;//消耗能量

        }

        jingyan_gain = M/jingyan_now;

        jingyan_now += jingyan_gain;//累加战斗值

    }

    printf("%d\n",jingyan_now);

    return 0;

}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论