第几天?
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 207852 Accepted Submission(s): 72633
Problem Description
给定一个日期,输出这个日期是该年的第几天。
Input
输入数据有多组,每组占一行,数据格式为YYYY/MM/DD组成,具体参见sample input ,另外,可以向你确保所有的输入数据是合法的。
Output
对于每组输入数据,输出一行,表示该日期是该年的第几天。
Sample Input
1985/1/20
2006/3/12
Sample Output
20
71
问题链接: 第几天?.
问题简述:
输入日期,输出这是那年的第几天。
问题分析:
这个问题的重点:1.输入的时候是带“/”的,不是整型 2.每个月的天数都不一样 3.闰年中二月会多一天
程序说明:
利用字符串接收输入的数据,再转换成整型变量,再进行判断。判断时挑出一月和二月和其他月份。再其他月份那里在细分。。。。。。(感觉我这个要打的东西好多)
AC通过的C语言程序如下:
#include<iostream>
#include<iomanip>
using namespace std;
int main()
{
char time[12] = { 0 };
int year, month, day;
int a = 0;
while (cin >> time)
{
year = 0; month = 0; day = 0; a = 0;
while (47 != time[a])
{
year = year * 10 + int(time[a] - 48);
a++;
}
a++;
while (47 != time[a])
{
month = month * 10 + int(time[a] - 48);
a++;
}
a++;
while (0 != time[a])
{
day = day * 10 + int(time[a] - 48);
a++;
}
if (month == 1) cout << day << endl;
else
{
if (month == 2)cout << 31 + day << endl;
else
{
if (year % 4 == 0 && year % 100 != 0 || year % 400 == 0)
{
switch (month)
{
case 3:cout << day + 31 + 29 << endl; break;
case 4:cout << day + 31 + 29 + 31 << endl; break;
case 5:cout << day + 31 + 29 + 61 << endl; break;
case 6:cout << day + 31 + 29 + 92 << endl; break;
case 7:cout << day + 31 + 29 + 122 << endl; break;
case 8:cout << day + 31 + 29 + 153 << endl; break;
case 9:cout << day + 31 + 29 + 184 << endl; break;
case 10:cout << day + 31 + 29 + 214 << endl; break;
case 11:cout << day + 31 + 29 + 245 << endl; break;
case 12:cout << day + 31 + 29 + 275 << endl; break;
default: break;
}
}
else
{
switch (month)
{
case 3:cout << day + 31 + 28 << endl; break;
case 4:cout << day + 31 + 28 + 31 << endl; break;
case 5:cout << day + 31 + 28 + 61 << endl; break;
case 6:cout << day + 31 + 28 + 92 << endl; break;
case 7:cout << day + 31 + 28 + 122 << endl; break;
case 8:cout << day + 31 + 28 + 153 << endl; break;
case 9:cout << day + 31 + 28 + 184 << endl; break;
case 10:cout << day + 31 + 28 + 214 << endl; break;
case 11:cout << day + 31 + 28 + 245 << endl; break;
case 12:cout << day + 31 + 28 + 275 << endl; break;
default: break;
}
}
}
}
}
return 0;
}