7-5 计算天数
作者 沈睿
单位 浙江大学
本题要求编写程序计算某年某月某日是该年中的第几天。
输入格式:
输入在一行中按照格式“yyyy/mm/dd”(即“年/月/日”)给出日期。注意:闰年的判别条件是该年年份能被4整除但不能被100整除、或者能被400整除。闰年的2月有29天。
输出格式:
在一行输出日期是该年中的第几天。
输入样例1:
2009/03/02
输出样例1:
61
输入样例2:
2000/03/02
输出样例2:
62
鸣谢湖北汽车工业学院袁科老师、用户潘明智补充数据!
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
栈限制
8192 KB
代码
#include <bits/stdc++.h>
using namespace std;
// 判断是否为闰年
bool ifRun(int year)
{
if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0)
return true;
return false;
}
int main()
{
int year, month, day;
scanf("%d/%d/%d", &year, &month, &day);
int resultNum = 0;
for (int i = 1; i < month; i++)
{
switch (i)
{
case 1:
case 3:
case 5:
case 7:
case 8:
case 10:
case 12:
resultNum += 31;
break;
case 4:
case 6:
case 9:
case 11:
resultNum += 30;
break;
case 2:
switch (ifRun(year))
{
case true:
resultNum += 29;
break;
default:
resultNum += 28;
break;
}
break;
}
}
resultNum += day;
cout << resultNum;
return 0;
}
优化代码
#include <bits/stdc++.h>
using namespace std;
// 判断是否为闰年
bool isLeapYear(int year)
{
return (year % 4 == 0 && year % 100 != 0) || (year % 400 == 0);
}
// 每个月的天数
int daysInMonth(int month, bool leapYear)
{
switch (month)
{
case 1:
case 3:
case 5:
case 7:
case 8:
case 10:
case 12:
return 31;
case 4:
case 6:
case 9:
case 11:
return 30;
case 2:
return leapYear ? 29 : 28;
default:
return 0;
}
}
int main()
{
int year, month, day;
scanf("%d/%d/%d", &year, &month, &day);
int resultNum = 0;
for (int i = 1; i < month; i++)
{
resultNum += daysInMonth(i, isLeapYear(year));
}
resultNum += day;
cout << resultNum;
return 0;
}
- 将月数包含的天数打包成函数,使得主函数更加简洁。
- 在判断2月包含的天数时,进行了优化,使得更加简洁。
- 对判断是否闰年进行了小优化。