回顾了一下这个题的原先解决思路,不能保证按此思路下去是否能作对这道题,于是另辟蹊径。


解题思路: 

就是闰年比较麻烦,需要先判断。我列了2个数组,一个是闰年的,一个不是闰年的。通过


注意事项:

编程时注意到以下的两点:

1.判断闰年的方法;2.题干中的要求:“输入数据有多组”;


参考代码:

#include<stdio.h>

int main()

{

int day=0,i;

int Y,M,D;

int a1[14]={0,31,29,31,30,31,30,31,31,30,31,30,31};//闰年数组。最开始的0是为当输入是1月X号时,计算整月日子的。

int a2[14]={0,31,28,31,30,31,30,31,31,30,31,30,31};//非闰年数组,

while(scanf("%d/%d/%d", &Y, &M,&D)==3)

{

if(Y%4==0&&Y%100!=0||Y%400==0)//判断条件,条件成立用a1数组,否则用a2数组。

{for(i=0;i<M;i++)

day=day+a1[i];

printf("%d\n",day+D);}//这里的day表示已经过完的整月都有几天,D表示这个月过了几天。

else

{for(i=0;i<M;i++)

day=day+a2[i];

printf("%d\n",day+D);}

}

return 0;

}


点赞(1)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 1 条评论

H2030819026 4年前 回复TA
你的代码是错的呀小子