17984 FFF团的怒火

该题有题解

时间限制:1000MS  内存限制:65535K
提交次数:55 通过次数:3 收入:3

题型: 编程题   语言: G++;GCC;VC;JAVA

Description

在信软学院,男女比例失衡已经是习以为常的事情。
在这样的一个学院,诞生了一个神秘的组织,FFF团。
O O O
/F\/F\/F\
/ \/ \/ \
他们的任务是将一切不是真爱的爱情扼杀在摇篮中。
对于某些信软学院的学生,每天都只有一些时间是空闲的,其他时间都只能默默地打代码。
在这段空闲的时间里,所有男生都会去寻找一位空闲的女生,希望能与其进行一次美妙的约会。
然而FFF团的团长——小邪早已看穿一切。
为了防止FFF团团员做出过激行为,小邪决定对所有有着同一段空闲时间的异性进行监控。
现在,小邪想知道,这样的异性有多少对。但是如果小邪现在不对团员进行监控,将会发生严重的后果,于是,统计的任务就交了给你。 出题人:K·小邪

输入格式

第一行是两个整数n,m(0 <= n,m <= 100),分别代表男生的数量和女生的数量

接下来输入n个男生的数据,对于每个男生有一组数据
每组数据的第一行为一个整数t( 0 <= t <= 10 ),代表该男生拥有的空闲时间段数量
接下来为t行
每行的格式为XX:XX-XX:XX (00:00 <= XX:XX <= 23:59)
代表其在XX:XX至XX:XX的时间段有空闲时间,但是可能跨越一天 接下来m个女生的数据,输入格式同男生

输出格式

输出一个整数,代表有可能见面的男女的对数

输入样例

(Sample #XX:不是输入的一部分)
Sample #1: 1 1
1
23:59-00:01
1
08:00-19:00 Sample #2: 1 2
2
19:30-19:33
00:00-08:00
1
07:30-09:00
1
19:30-19:33

输出样例

Sample #1:
0 Sample #2:
2

提示

注意端点相交也算是有可能见面的
比如08:00-09:00是可能与09:00-10:00见面的
并且对于同一个人输入的区间可能有重叠 这题都说不清楚的,不知道跨了一天算明天的还是算谁。然后是算同一天的,也就是
23:59-07:00 和 01:00-02:00是相交的。。。晕。。
然后这题又不能用scanf("%d",) != EOF,这样会错误。。坑啊
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <algorithm>
#define IOS ios::sync_with_stdio(false)
using namespace std;
#define inf (0x3f3f3f3f)
typedef long long int LL; #include <iostream>
#include <sstream>
#include <vector>
#include <set>
#include <map>
#include <queue>
#include <string>
const int maxn = + ;
struct node {
int num;
bool book[maxn];
}boy[ + ], girl[ + ];
int n, m;
void work() {
scanf("%d%d", &n, &m);
for (int i = ; i <= n; ++i) {
int t;
scanf("%d", &t);
boy[i].num = t;
while (t--) {
int a, b, c, d;
scanf("%d:%d-%d:%d", &a, &b, &c, &d);
int begin = a * + b;
int end = c * + d;
if (begin > end) {
for (int j = begin; j <= ; ++j) {
boy[i].book[j] = true;
}
for (int j = ; j <= end; ++j) {
boy[i].book[j] = true;
}
} else {
for (int j = begin; j <= end; ++j) {
boy[i].book[j] = true;
}
}
}
}
for (int i = ; i <= m; ++i) {
int t;
scanf("%d", &t);
girl[i].num = t;
while (t--) {
int a, b, c, d;
scanf("%d:%d-%d:%d", &a, &b, &c, &d);
int begin = a * + b;
int end = c * + d;
if (begin > end) {
for (int j = begin; j <= ; ++j) {
girl[i].book[j] = true;
}
for (int j = ; j <= end; ++j) {
girl[i].book[j] = true;
}
} else {
for (int j = begin; j <= end; ++j) {
girl[i].book[j] = true;
}
}
}
}
int ans = ;
for (int i = ; i <= n; ++i) {
for (int j = ; j <= m; ++j) {
for (int k = ; k <= maxn - ; ++k) {
if (boy[i].book[k] && girl[j].book[k]) {
ans++;
break;
}
}
}
}
printf("%d\n", ans);
} int main() {
#ifdef local
freopen("data.txt","r",stdin);
#endif
work();
return ;
}
05-11 17:14