雇佣兵的体力最大值为 MM,初始体力值为 00、战斗力为 NN、拥有 XX 个能量元素。
当雇佣兵的体力值恰好为 MM 时,才可以参加一个为期 MM 天的战斗期,战斗期结束体力值将为 00。在同一个战斗期内,雇佣兵每连续战斗 nn 天,战斗力就会上升 11 点,nn 为当前战斗期开始时的战斗力。
一个战斗期结束后,雇佣兵需要用若干个能量元素使其体力恢复到最大值 MM,从而参加下一个战斗期。每个能量元素恢复的体力值不超过当前的战斗力。每个能量元素只能使用一次。
请问:雇佣兵的战斗力最大可以到达多少。
说明:只在战斗期结束后可以使用能量元素,可以使用多个能量元素。
输入格式
一行包括三个整数 MM、NN、XX,相邻两个整数之间用单个空格隔开。MM、NN、XX 均为不超过 1000010000 的正整数。
输出格式
输出一个整数,为雇佣兵的最大战斗力。
输出时每行末尾的多余空格,不影响答案正确性
样例输入
5 2 10
样例输出 ``
6
#include "iostream"
using namespace std;
int main()
{
int m,n,x;
cin>>m>>n>>x;
while(m>=n)
{
if(m%n)
x=x-1-m/n;
else
x=x-m/n;
if(x>0) n+=m/n;
else if(x==0) {n+=m/n;break;}
else break;
}
cout<<n<<endl;
return 0;
}