人有体力、情商、智商的高峰日子,它们分别每隔23天、28天和33天出现一次。
给定三个高峰出现的日子p,e,i;再给定另一个日子d,计算出d之后三个高峰在同一天出现的日子(用距离d的天数作为输出)。
例如,给定d为10,三个高峰出现同一天为12,则输出为2;
枚举也要尽可能的减少枚举次数,剔除不可能的情况
#include<iostream>
using namespace std;
int main()
{
int a,b,c,d,k;
while(cin>>a>>b>>c>>d&&a!=-1)
{
for(k=d+1;(k-a)%23;k++);//算出体力高峰的日子
for(;(k-b)%28;k+=23);//算出情商高峰的日子,在满足体力高峰的情况
for(;(k-c)%33;k+=23*28);//算出智商高峰的日子,在满足体力、情商高峰的情况
//减少循环次数
cout<<k-d<<endl;
}
return 0;
}
给定三个高峰出现的日子p,e,i;再给定另一个日子d,计算出d之后三个高峰在同一天出现的日子(用距离d的天数作为输出)。
例如,给定d为10,三个高峰出现同一天为12,则输出为2;
枚举也要尽可能的减少枚举次数,剔除不可能的情况
#include<iostream>
using namespace std;
int main()
{
int a,b,c,d,k;
while(cin>>a>>b>>c>>d&&a!=-1)
{
for(k=d+1;(k-a)%23;k++);//算出体力高峰的日子
for(;(k-b)%28;k+=23);//算出情商高峰的日子,在满足体力高峰的情况
for(;(k-c)%33;k+=23*28);//算出智商高峰的日子,在满足体力、情商高峰的情况
//减少循环次数
cout<<k-d<<endl;
}
return 0;
}