题目描述
人有体力、情商、智商的高峰日子,它们分别每隔23天、28天和33天出现一次。对于每个人,我们想 知道何时三个高峰落在同一天。给定三个高峰出现 的日子p,e和i(不一定是第一次高峰出现的日子), 再给定另一个指定的日子d,你的任务是输出日子d 之后,下一次三个高峰落在同一天的日子(用距离d 的天数表示)。例如:给定日子为10,下次出现三个高峰同一天的日子是12,则输出2。
题目来源
#include <iostream>
using namespace std;
int main()
{
int p, e, i, d;
int nextday;//可能的结果
int count = 1;
while (cin >> p >> e >> i >> d && p != -1)//p为-1或者没有连续输入四个int数
{
nextday = d + 1;//从d的下一天开始
while ((nextday - p) % 23)
{
nextday++;
}; //找到第一个p高峰
while ((nextday - e) % 28)
{
nextday += 23;
}; //找到第一个既是p高峰又是e高峰
while ((nextday - i) % 33)
{
nextday += 23 * 28;
}; //找到第一个即是p高峰又是e高峰还是i高峰
cout << "Case " << count++ << ": the next triple peak occurs in " << nextday - d << " days.\n";
}
}
Tips:
int a=5;
while(a++==5)
{
cout<<"先进行a==5运算,在while进入循环体之后,再进行a++运算,所以输出这句话,并且a的值是"<<a; //此时a的值已经是6
};