- 题目描述
今年的植树节(20122012 年 33 月 1212 日),小明和他的叔叔还有小伙伴们一起去植树。休息的时候,小明的同学问他叔叔多大年纪,他叔叔说:“我说个题目,看你们谁先猜出来!”
“把我出生的年月日连起来拼成一个 88 位数(月、日不足两位前补 00)正好可以被今天的年、月、日整除!”
他想了想,又补充到:“再给个提示,我是 66 月出生的。”
根据这些信息,请你帮小明算一下,他叔叔的出生年月日。
格式是年月日连成的 88 位数。例如,如果是 19481948 年 66 月 1212 日,就写:1948061219480612。
- 运行限制
最大运行时间:1s
最大运行内存:128M
此题的大意较好理解,其中月份已经明晰,即所求时间为××××06××
,我们先设一个变量满足上述要求,然后遍历自增添加条件判断语句来跑这个程序。话不多说,上代码。
#include<iostream>
using namespace std;
int main()
{
int a=10000+6*100;
for(int i=a;i<20120312;i++)
{
if(i/100%100==6&&i>19000000)
{
if(i%2012==0)
{
if(i%3==0)
{
if(i%12==0)
{
cout<<i<<endl;
}
}
}
}
}
return 0;
}
初代程序通过设置一个变量存储符合题意的时间,然后通过经典的年份判断出月份加以判断,最后加上年、月、日的条件嵌套判断暴力求解。程序跑完如图。
出现了三个时间,并不意味此题得解,该题为填空题,只有一个正解(笑哭)。细看日期不符合常识,6月份日期应≤30天。改良版代码为:
#include<iostream>
using namespace std;
int main()
{
int a=10000+6*100;
for(int i=a;i<20120312;i++)
{
if(i%100<=30&&i/100%100==6&&i>19000000)
{
if(i%2012==0)
{
if(i%3==0)
{
if(i%12==0)
{
cout<<i<<endl;
}
}
}
}
}
return 0;
}
跑完程序为
问题得到解决。