原题:
在西方,星期五和数字 13都代表着坏运气,两个不幸的个体最后结合成超级不幸的一天。所以,不管哪个月的十三日又恰逢星期五就叫“黑色星期五”。
要求:输入年份,输出是:判断该年是否包含黑色星期五,如包含,给出具体日期
下面是我的代码:
#include<stdio.h>
int runyear(int y)
{
if(y%10==0)
{
if(y%400==0)
{
return 1;
}
else return 0;
}
else
{
if(y%4==0&&y%100!=0)
{
return 1;
}
else return 0;
}
}
int runmonth(int y,int m)
{
int s;
if(runyear(y))
{
if(m<=7)
{
if(m==2) s=29;
else if(m%2!=0) s=31;
else s=30;
}
else if(m>7)
{
if(m%2==0) s=31;
else s=30;
}
}
else if(!runyear(y))
{
if(m<=7)
{
if(m==2) s=28;
else if(m%2!=0) s=31;
else s=30;
}
else if(m>7)
{
if(m%2==0) s=31;
else s=30;
}
}
return s;
}
int xinqi(int y,int m,int d)
{
int y0,m0,d0,xq=4;
y0=1998;m0=1;d0=1;
while(1)
{
d0++;
xq++;
if(xq>7)
{
xq=1;
}
if(d0>runmonth(y0,m0))
{
d0=1;
m0++;
if(m0>12)
{
m0=1;
y0++;
}
}
if(y0==y&&m0==m)
{
if(d0==d)
{
return xq;
}
}
}
}
main()
{
int year,i,m=1,d=0,count=0;
scanf("%d",&year);
if(runyear(year))
{
for(i=1;i<=366;i++)
{
d++;
if(d==13&&xinqi(year,m,d)==5)
{
count++;
}
if(d>runmonth(year,m))
{
d=1;
m++;
}
}
}
else
{
for(i=1;i<=365;i++)
{
d++;
if(d==13&&xinqi(year,m,d)==5)
{
count++;
}
if(d>runmonth(year,m))
{
d=1;
m++;
}
}
}
printf("%d年有%d个黑色星期五",year,count);
}
有一个重要的已知:
1998年1月1日是星期四,代码其实很好理解的。