合抱之木,生于毫末;九层之台,起于累土;千里之行,始于足下。💪🏻
一、题目描述 ⭐️
练习7-9 计算天数
本题要求编写程序计算某年某月某日是该年中的第几天。
输入格式:
输入在一行中按照格式“yyyy/mm/dd”(即“年/月/日”)给出日期。注意:闰年的判别条件是该年年份能被4整除但不能被100整除、或者能被400整除。闰年的2月有29天。
输出格式:
在一行输出日期是该年中的第几天。
输入样例1:
2009/03/02
输出样例1:
61
输入样例2:
2000/03/02
输出样例2:
62
二、解题思路 ⭐️
【口诀 ❀】
- 1月大(31),
- 2月平(闰年 29,非闰年 28),
- 3月大(31),
- 4月小(30),
- 5月大(31),
- 6月小(30),
- 7月大、8月大(31),
- 9月小(30),
- 10月大(31),
- 11月小(30),
- 12月大(31)。
三、代码(C语言)⭐️
#include <stdio.h>
// 判断是否为闰年的函数
int isRunnian(int year) {
// 如果年份能被4整除但不能被100整除,或者能被400整除,则是闰年
if((year % 4 == 0 && year % 100 != 0) || year % 400 == 0) {
return 1; // 返回1表示是闰年
}
return 0; // 返回0表示不是闰年
}
// 获取某年某月的天数
int get_month_day(int year, int month) {
/**【口诀】1月大,2月平,3月大,4月小,5月大,6月小,7月大、8月大,9月小,10月大,11月小,12月大 */
switch(month) {
case 4: // 4月
case 6: // 6月
case 9: // 9月
case 11: // 11月
return 30; // 这些月份有30天
break;
case 2: // 2月
return isRunnian(year) == 1 ? 29 : 28; // 闰年2月有29天,否则28天
break;
default: // 其他月份
return 31; // 其他月份有31天
break;
}
}
int main() {
int year, // 年份
month, // 月份
day; // 日
// 输入日期,格式为 "年/月/日"
scanf("%d/%d/%d", &year, &month, &day);
int result = 0; // 用于存储计算的结果,即该日期是这一年的第几天
// 累加从1月到(month-1)月的天数
for(int i = 1; i < month; i++) {
result += get_month_day(year, i);
}
// 加上当前月的天数
result += day;
// 输出结果
printf("%d\n",result);
return 0; // 程序正常结束
}