解题思路:这个题不难,但是我写的很复杂。通过调用两个函数来计算是第几天,大家略看一下就能懂。
注意事项:我这种写法太浪费时间,看看就好,还是建议用两个数组代替我这两个函数。
参考代码:
#include<stdio.h>
struct Date
{
int year;
int month;
int day;
};
int dayr(int n)
{
int a;
if(n==1)
a=31;
else if(n==2)
a=29;
else if(n==3)
a=31;
else if(n==4)
a=30;
else if(n==5)
a=31;
else if(n==6)
a=30;
else if(n==7)
a=31;
else if(n==8)
a=31;
else if(n==9)
a=30;
else if(n==10)
a=31;
else if(n==11)
a=30;
else if(n==12)
a=31;
return a;
}
int dayp(int n)
{
int a;
if(n==1)
a=31;
else if(n==2)
a=28;
else if(n==3)
a=31;
else if(n==4)
a=30;
else if(n==5)
a=31;
else if(n==6)
a=30;
else if(n==7)
a=31;
else if(n==8)
a=31;
else if(n==9)
a=30;
else if(n==10)
a=31;
else if(n==11)
a=30;
else if(n==12)
a=31;
return a;
}
int main()
{
int day=0;
struct Date date;
scanf("%d%d%d",&date.year,&date.month,&date.day);
if(date.year%4==0&&date.year%100!=0||date.year%400==0)
{
if(date.month==1)
printf("%d",date.day);
else
{
for(int i=date.month-1;i>0;i--)
{
day=day+dayr(i);
}
printf("%d",day+date.day);
}
}
else
{
if(date.month==1)
printf("%d",date.day);
else
{
for(int i=date.month-1;i>0;i--)
{
day=day+dayp(i);
}
printf("%d",day+date.day);
}
}
return 0;
}
0.0分
1 人评分
C语言程序设计教程(第三版)课后习题9.2 (Java代码)浏览:696 |
用筛法求之N内的素数。 (C语言代码)浏览:1385 |
字符串的输入输出处理 (C语言代码)浏览:1019 |
C语言程序设计教程(第三版)课后习题6.10 (C语言代码)浏览:900 |
C语言程序设计教程(第三版)课后习题7.5 (C语言代码)浏览:548 |
C语言程序设计教程(第三版)课后习题7.5 (C语言代码)浏览:900 |
【简单计算】 (C语言代码)浏览:642 |
DNA (C语言代码)浏览:440 |
DNA (C语言代码)浏览:798 |
1048题解(读入回车问题)浏览:628 |