文章目录
一.题目
题目太长了QWQ
传送门
二.Solution
第一眼看到这道题目,wdnm,题目是真的又臭又长,要求还很多,直接把我人给看傻了。但我也没办法,只能硬着头皮给看下去。因为没有什么思维含量,这里提供一些细节:
- 长跑时间和休息时间如果没上两位数题目是只给一位数的,比如9’9’’,但别忘了还有89’45’'等情况;
- 男女有别;
- 分数没说的一律算0分,比如阳光长跑连三次都没有达到,就直接0分;
- 阳光长跑的时间不会有跨天跨月或者跨年;
- 两次阳光长跑之间的时间间隔是前一次的结束与后一次的开始之间的间隔(我就错这调了1h QWQ),如果是第一次,就直接通过;
- 时间最好全部化成秒直接相减,包括天月都化成秒,月直接求个前缀和就行了。
祝你好运。。。
三.Code
#include <cstdio>
#include <cstring>
#include <iostream>
#include <map>
using namespace std;
#define LL long long
struct node {
bool sex;
int grade, c, sun_run;
LL lst_time;
};
map <LL, node> mp;
int n, m;
LL a[4005], sum_month[20] = {
0, 0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334};
int check_long_run (int sex, char *long_run){
int mi = (long_run[1] >= '0' && long_run[1] <= '9') ? ((long_run[0] - 48) * 10 + long_run[1] - 48) : (long_run[0] - 48);
int se;
if (mi >= 10 && long_run[4] >= '0' && long_run[4] <= '9')
se = (long_run[3] - 48) * 10 + long_run[4] - 48;
else if (mi >= 10)
se = long_run[3] - 48;
else if (long_run[3] >= '0' && long_run[3] <= '9')
se = (long_run[2] - 48) * 10 + long_run[3] - 48;
else
se = long_run[2] - 48;
if (sex == 1){
if (mi <= 12 && se <= 30) return 20;
if ((mi == 12 && 30 < se && se <= 59) || (mi == 13 && se == 0)) return 18;
if (mi == 13 && 0 < se && se <= 30) return 16;
if ((mi == 13 && 30 < se && se <= 59) || (mi == 14 && se == 0)) return 14;
if (mi == 14 && 0 < se && se <= 30) return 12;
if ((mi == 14 && 30 < se && se <= 59) || (mi == 15 && 0 <= se && se &