这道题开始做的时候,不知道为什么,怎么算月后面的days都少1天
后来ask Mr.S,他说他通过边界测试,输入0的时候发现显示的是2000-1-0
所以知道了原因在哪里
他建议我看看软件测试这本书,对于编程有好处
虽然没有上过软件测试的课程,但是这本书还是挺简单的
我将其纳入计划
多看看
下面将这段代码贴上来,开始的时候以为自己做不出来,有点难度,后来发现,其实不难
所以面对问题的时候,要遇难而上,总会有柳暗花明的一天,要相信自己的潜力,很多想象不到的东西
终有一天是属于自己的。
这道题的思路就是:先确定年,再确定月,再确定日,不断的从总天数里减去度过的年数月数日数。星期几的计算巧妙的用了一个字符串数组来与days与7的余数对应起来,当然这个对应与初始的2000年1月1日是 周六有关系。
#include <stdio.h>
#include <stdlib.h>
//判断是否为闰年
int isRunYear(int year)
{
if(year%100==0&&year%400!=0)
{
return 0;
}
if(year%4==0)
{
return 1;
}
else
return 0;
}
int main()
{
int days;
scanf("%d",&days);
while(days!=-1){
// 计算dayofweek
int week=days%7;
char a[7][10];
strcpy(a[0],"Saturday");
strcpy(a[1],"Sunday");
strcpy(a[2],"Monday");
strcpy(a[3],"Tuesday");
strcpy(a[4],"Wednesday");
strcpy(a[5],"Thursday");
strcpy(a[6],"Friday");
//对年的处理
int year=2000;
days=days+1; //很重要,当输入days=0的时候,显示为2000年1月0号,根本没有这一天
while(days>365){
if(isRunYear(year)==1)
{
days=days-366;
if(days<=0)
{
days=days+366;
break;
}
}else
{
days=days-365;
}
year=year+1;
}
//对月份的处理
int month=1;
while(days>28){
if(month==1||month==3||month==5||month==7||month==8||month==10||month==12)
{
days=days-31;
if(days<=0)
{
days=days+31;
break;
}
}else if(month==4||month==6||month==9||month==11)
{
days=days-30;
if(days<=0)
{
days=days+30;
break;
}
}else if(month==2)
{
if(isRunYear(year)==1)
{
days=days-29;
if(days<=0)
{
days=days+29;
break;
}
}else
{
days=days-28;
}
}
month=month+1;
}
//按照要求的格式输出
printf("%d",year);
if(month<10)
printf("-0%d",month);
else
printf("-%d",month);
if(days<10)
printf("-0%d %s\n",days,a[week]);
else
printf("-%d %s\n",days,a[week]);
scanf("%d",&days);
}
return 0;
}