比赛场次 | 204 |
---|---|
比赛名称 | 20130524 |
比赛状态 | 已结束比赛成绩 |
开始时间 | 2013-05-24 19:00:00 |
结束时间 | 2013-05-24 22:00:00 |
开放分组 | 全部用户 |
注释介绍 |
题目名称 | 切割矩形 |
---|---|
输入输出 | cutting.in/out |
时间限制 | 1000 ms (1 s) |
内存限制 | 256 MiB |
测试点数 | 20 简单对比 |
用户 | 结果 | 时间 | 内存 | 得分 |
---|---|---|---|---|
cstdio | AAAAAAAATTTTTTTTTTTT |
12.003 s | 0.73 MiB | 40 |
feng | AAAAAAAATTTTTTTTTTTT |
12.005 s | 0.75 MiB | 40 |
苏轼 | AWWWWWWWTTTTTTTTTTTT |
12.002 s | 1.23 MiB | 5 |
gungnir | AWWWWWWWTTTTTTTTTTTT |
12.006 s | 0.62 MiB | 5 |
【问题描述】
有一些实心的矩形,它们的边都平行于平面直角坐标轴,小Bug画了一些平行于X轴的线段,他想知道被这些线段切割到的实心矩形数目,一个实心矩形被一条线段切割到当且仅当它们至少有一个交点,如果一个实心矩形被K条线段切割,将被计算K次。
【输入格式】
输入文件第一行有一个正整数T,T<=20,表示接下来有T个测试数据。
每个测试数据的第一行有一个正整数N,N<=30000,表示实心矩形的数目,接下来有N行,每行有4个非负整数:x1,y1,x2,y2,表示对应矩形的左下角及右上角坐标,满足x1<x2且y1<y2;接下来有一个正整数Q,Q<=30000,表示线段的数目,接下来有Q行,每一行有4个非负整数:x3,y3,x4,y4,分别表示对应线段的两个端点坐标,其中x3<x4且y3=y4。
所有的整数都不超过100000000。
【输出格式】
对于每个测试数据,输出有一行,包含一个整数,即被这些线段切割到的实心矩形总数。
【输入样例】
cutting.in
1
3
1 1 3 4
2 3 4 5
5 1 6
3
5
0 1 6 1
0 3 6 3
0 5 6 5
0 5 2 5
0 6 2 6
cutting.out
7