分析以下:
先定义year,month,day.
我先判断日期中有闰年这种特殊情况二月有29天否则有28天,1,3,5,7,8,10,12,有31天
2,4,6,9,11有30天。定义sum求和,让for循环运行year取余运算后最重要一步就是
sum不知道等于多少数完全平方数,定义i后用 for循环一个来推出它:
for(i=1;i<7;i++)//因为我只算最大值sum就行了
{if(sum==i*i)
count++;}
这个就思路就行了。
看以下程序:
#include<stdio.h>
int main()
{int year;
int month;
int day;
int count=0;
int sum;
int n;
int i;
for(year=2001;year<2022;year++)
for(month=1;month<=12;month++)
{
switch(month){
case 1: case 3: case 5:
case 7:case 8:case 10: case 12: n=31;break;
case 11: case 4: case 6: case 9: n=30;break;
case 2:if((year%100!=0)&&(year%4==0)||(year%400==0))
n=29;
else n=28;
break;
}
for(day=1;day<=n;day++)
{sum=0;
int red1,red2,red3;
for(red1=year;red1!=0;red1/=10)
sum+=red1%10;
for(red2=month;red2!=0;red2/=10)
sum+=red2%10;
for(red3=day;red3!=0;red3/=10)
sum+=red3%10;
for(i=1;i<7;i++)
{if(sum==i*i)
count++;
}
}
}
printf("%d",count);//977
return 0;
}
运行结果为977.
如果知道这个日期推出这个规律为
if(sum==9||sum==16||sum==25)
count++;
我们可以写以下程序:
#include<stdio.h>
int main()
{int year;
int month;
int day;
int count=0;
int sum;
int n;
int i;
for(year=2001;year<2022;year++)
for(month=1;month<=12;month++)
{
switch(month){
case 1: case 3: case 5:
case 7:case 8:case 10: case 12: n=31;break;
case 11: case 4: case 6: case 9: n=30;break;
case 2:if((year%100!=0)&&(year%4==0)||(year%400==0))
n=29;
else n=28;
break;
}
for(day=1;day<=n;day++)
{sum=0;
int red1,red2,red3;
for(red1=year;red1!=0;red1/=10)
sum+=red1%10;
for(red2=month;red2!=0;red2/=10)
sum+=red2%10;
for(red3=day;red3!=0;red3/=10)
sum+=red3%10;
if(sum==9||sum==16||sum==25)
count++;
}
}
printf("%d",count);
return 0;
}
这个地方有不好地方请指教一下,谢谢大家观看!