猜生日(省赛)

  1. 题目描述
    今年的植树节(20122012 年 33 月 1212 日),小明和他的叔叔还有小伙伴们一起去植树。休息的时候,小明的同学问他叔叔多大年纪,他叔叔说:“我说个题目,看你们谁先猜出来!”

“把我出生的年月日连起来拼成一个 88 位数(月、日不足两位前补 00)正好可以被今天的年、月、日整除!”

他想了想,又补充到:“再给个提示,我是 66 月出生的。”

根据这些信息,请你帮小明算一下,他叔叔的出生年月日。

格式是年月日连成的 88 位数。例如,如果是 19481948 年 66 月 1212 日,就写:1948061219480612。

  1. 运行限制
    最大运行时间: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;

}

跑完程序为
猜生日(省赛)
问题得到解决。
猜生日(省赛)

上一篇:1446: 蓝桥杯2013年第四届真题-核桃的数量


下一篇:蓝桥杯-星期一-Python详解