雇佣兵

简介: 题目链接:http://noi.openjudge.cn/ch0105/37/总时间限制: 1000ms内存限制: 65536kB描述雇佣兵的体力最大值为M,初始体力值为0、战斗力为N、拥有X个能量元素。

题目链接:http://noi.openjudge.cn/ch0105/37/

总时间限制: 1000ms内存限制: 65536kB
描述

雇佣兵的体力最大值为M,初始体力值为0、战斗力为N、拥有X个能量元素。

当雇佣兵的体力值恰好为M时,才可以参加一个为期M天的战斗期,战斗期结束体力值将为0。在同一个战斗期内,雇佣兵每连续战斗n天,战斗力就会上升1点,n为当前战斗期开始时的战斗力。

一个战斗期结束后,雇佣兵需要用若干个能量元素使其体力恢复到最大值M,从而参加下一个战斗期。每个能量元素恢复的体力值不超过当前的战斗力。每个能量元素只能使用一次。

请问:雇佣兵的战斗力最大可以到达多少。

输入
一行包括三个整数M、N、X,相邻两个整数之间用单个空格隔开。M、N、X均为不超过10000的正整数。
输出
输出一个整数,为雇佣兵的最大战斗力。
样例输入
5 2 10
样例输出
6

PS:这道题真没看懂题目是什么意思,尤其能力元素x的消耗量是怎么定义的。

下面是别人的代码,从代码推销题目意思,似乎题目意思也不是跟代码一个样啊……

哪位朋友理解了题目意思,还希望能给留言解析一下

 1 #include<stdio.h>
 2 #include<math.h>
 3 int main()
 4 {
 5     int m,n,x;
 6     scanf("%d%d%d",&m,&n,&x);//体力、战斗力、能量元素 
 7     //如果刚开始他的战斗力大于m ,那么战斗m天凑不够n天,所以他的战斗力值不会增加
 8     //循环体中,能量减少(m/n向上取整),战斗力增加(m/n向下取整),直到能量用完。
 9     while(n<=m&&x)
10     {
11         x-=ceil( ((double)m)/n);
12         if(x<0) break;
13         n+=floor(((double)m)/n);
14     }
15     printf("%d\n",n);
16 }

 

相关文章
|
8月前
|
安全 数据安全/隐私保护 C++
C/C++基础知识——字符串(二)
C/C++基础知识——字符串
278 0
|
8月前
|
传感器 监控 安全
LabVIEW开发汽车安全带张紧测试
LabVIEW开发汽车安全带张紧测试
67 3
|
8月前
|
人工智能 数据挖掘 索引
NumPy 初学者指南中文第三版:11~14
NumPy 初学者指南中文第三版:11~14
100 0
|
缓存 算法 物联网
物联网通信技术期末复习3:第三章数据链路层
其中需要掌握常见的差错检测和分段技术。 熟悉静态接入技术 与 随机接入技术的典型方法与基本原理。
物联网通信技术期末复习3:第三章数据链路层
|
设计模式 SQL 监控
优化Java性能的五种方法
优化Java性能的五种方法
|
开发工具 git
Git高级操作
Git高级操作
|
Android开发
【Android 异步操作】Handler 机制 ( Handler 常用用法 | HandlerThread 简介 | HandlerThread 源码注释分析 )
【Android 异步操作】Handler 机制 ( Handler 常用用法 | HandlerThread 简介 | HandlerThread 源码注释分析 )
141 0
|
XML Linux Shell
kvm 虚拟化教程
虚拟化是门技术,云计算是个模式(概念)
1882 0
|
监控 Java Apache
补习系列(1)-springboot项目基础搭建课
目录 前言 一、基础结构 二、添加代码 三、应用配置 四、日志配置 五、打包部署 小结 前言 springboot 最近火的不行,目前几乎已经是 spring 家族最耀眼的项目了。抛开微服务、技术社区这些推广因素不说,框架本身的确有非常多的优点。
2557 0