题目分析:
首先我们应该想到每一年的天数是不一样的,并且每个月份的天数也是不一样的,所以我们需要考虑是否润年以及大小月份的问题。
1,关于润年的判断方法
(1)十年一润百年不润:即如果该年份能够被4整除,但是不能被100整除,则该年是润年。
(2)每四百年再一润:如果该年份能够被400整除,则该年份是润年。
#include<stdio.h>
int main()
{
int year;
printf("请输入需要判断的年份:");
scanf_s("%d", &year);
if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0) {
printf("%d为润年", year);
}
else
printf("%d不是润年",year);
return 0;
}
例如2000年为润年。
于是我们需要注意润年的二月份有29天,而其他年份则为28天,也就是说润年一共366天,其他年份则是365天。
代码实现:
#include<stdio.h>
int main()
{
int year, month, day, i;
printf("请输入您想要判断的年月日:");
scanf_s("%d,%d,%d" ,&year, &month, &day);
switch (month) {
case 1:i = 0; break;
case 2:i = 31; break;
case 3:i = 59; break;
case 4:i = 90; break;
case 5:i = 120; break;
case 6:i = 151; break;
case 7:i = 181; break;
case 8:i = 212; break;
case 9:i = 243; break;
case 10:i = 273; break;
case 11:i = 304; break;
case 12:i = 334; break;
default:printf("您的输入有误,请重新输入!!!"); break;
}
i = day + i;
if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0) {
if (month > 2) {
printf("该日期为%d的第%d天", year, i+1);
}else
printf("该日期为%d的第%d天", year, i);
}
else
printf("该日期为%d的第%d天", year, i);
return 0;
}
实现展示:
代码分析:
这个代码的核心思想是算出前几个月对应得天数总和再加上当月的天数即可求得结果,中间需要对是否为润年以及输入的月份是否大于2月做一个判断,如果为润年且月份数大于2,则最后的天数需要加上1天,其余则可以直接输出!!!
备注:
由于不同版本的编译器问题,如果发现无法运行,请将scanf_s改为scanf,本人使用VS 2022版本
2022年7月于福建
——暮炊雪