Tom也是一个ACM爱好者,从2000年1月1日就开始了ACM/ICPC的练习,一直坚持到现在。可惜的是,他一直采用的是这种“三天打渔两天晒网”的训练方式,也就是说,每做三天的训练,一定会休息两天,如此反复,直到今天。
现在的问题是:给你一个日期,你能计算出这一天Tom是在训练还是休息吗?
Input
输入数据首先包含一个整数T(T<=20),表示有T组测试数据,然后是T行,每行包含一个格式如“YYYY/MM/DD”的日期,题目保证所有日期在2000年1月1日和今天之间
Output
对于每个测试用例,如果Tom在这一天是训练,则请输出“Fishing”,否则,请输出“Resting”。
Sample Input
2
2000/01/03
2000/01/04
Sample Output
Fishing
Resting
#include<iostream>
#include<string>
using namespace std;
int main()
{
int h[13] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };
int uh[13] = { 0,31,29,31,30,31,30,31,31,30,31,30,31 };
int n;
cin >> n;
//getchar();
for (int i = 0; i < n; i++) {
int a, b, c;
scanf("%d/%d/%d", &a, &b, &c);//<1>
int q=0;
if (a % 4 == 0 && a % 100 != 0 || a % 400 == 0) {
for (int k = 1; k < b; k++) {
q = q + uh[k];
}
}
else {
for (int k = 1; k < b; k++) {
q = q + h[k];
}
}
q = q + c;
//cout << q << endl;
for (int j = 2000; j < a; j++) {
if (j % 4 == 0 && j % 100 != 0 || j % 400 == 0) {
q = q + 366;
//cout << 366 << endl;
}
else {
q = q + 365;
//cout << 365 << endl;
}
}
//cout << "date:" << q << endl;
if (q % 5==0||q%5==4||q%5==5)cout << "Resting" << endl;
else cout << "Fishing" << endl;
}
}
遇到的问题:
代码中<1>的部分我以前是这么写的:
string s;
getline(cin, s);
int a = int(s[0] - '0') * 1000 + int(s[1] - '0') * 100 + int(s[2] - '0') * 10 + int(s[3] - '0');
int b = int(s[5] - '0') * 10 + int(s[6] - '0');
int c = int(s[8] - '0') * 10 + int(s[9] - '0');
结果提示答案错误,所以说还是scanf大法好(滑稽)
char转int:int a=int(s-‘0’);