题目描述:
本题为填空题,只需要算出结果后,在代码中使用输出语句将所填结果输出即可。
小蓝特别喜欢2,今年是公元2020年,他特别高兴,因为每天日历上都可以看到2。
如果日历中只显示年月日,请问从公元1900年1月1日到公元9999年12月31日,一共有多少天日历上包含2。即有多少天中年月日的数位中包含数字2。
运行限制
- 最大运行时间:1s
- 最大运行内存: 128M
思路:
1.首先fun函数判断年月日的数位中是否包含数字2
2.3个循环判断某年某月某日里是否有2
3.判断年份是否为闰年,以此判断
核心代码:
int fun(int n)
{
while(n) //遍历一个数的每一位判断
{
if(n%10 == 2) //当前末位是否是2
return 1;
n = n/10; //原本是123,此次后是12
}
return 0;
}
源代码:
#include<stdio.h>
int fun(int n)
{
while(n) //遍历一个数的每一位判断
{
if(n%10 == 2) //当前末位是否是2
return 1;
n = n/10; //原本是123,此次后是12
}
return 0;
}
int main()
{
int i,j,k;
int month[13]={0,31,28,31,30,31,30,31,31,30,31,30,31}; //13是为了月份对应
int count=0;
for(i=1900; i<=9999; i++) //判断年
{
if((i%4==0 && i%100!=0) || i%400==0) //判断闰年与否
month[2]=29; //闰年2月29天
else
month[2]=28;
for(j=1; j<=12; j++) //判断月
{
for(k=1; k<=month[j]; k++) //判断日
{
if(fun(i)==1 || fun(j)==1 || fun(k)==1) //年月日中只要有一个有2就成立
count++;
}
}
}
printf("%d\n",count); //年月日的数位中包含数字2的天数
return 0;
}
答案:
在蓝桥杯里面是通过的。
类似例题:
源代码:
#include<stdio.h>
int fun(int n)
{
while(n)
{
if(n%10==2)
return 1;
n=n/10;
}
return 0;
}
int main()
{
int i;
int count=0;
for(i=1; i<=2020; i++)
{
if(fun(i) == 1)
count++;
}
printf("%d\n",count);
return 0;
}