UOJ Logo Universal Online Judge

UOJ

#366. 【JOISC2017】Dragon 2

附件下载 统计

在一个平面直角坐标系上有 $N$ 条龙,编号为 $1\dots N$;龙有 $M$ 支种族,编号为 $1\ldots M$。

$i$ 号龙 $(1\le i\le N)$ 位于 $(A_i, B_i)$,它属于种族 $C_i$。有可能有些种族已经没有龙了。

JOI 平原上有一条路,这条路可视为一条线段,端点坐标分别为 $(D_1, E_1)$ 和 $(D_2, E_2)$。

上文中提到的所有坐标互不相同,且没有三点共线。

不同种族的龙之间会发生冲突。现给出 $Q$ 种冲突,每种冲突用两个整数 $F_j, G_j$ 来描述 $(1\le j\le Q, 1\le F_j, G_j\le M)$,意为种族 $F_j$ 敌视种族 $G_j$。此时,种族 $F_j$ 的每一条龙会向种族 $G_j$ 的每一条龙发射一个火球。火球轨迹是一条射线,打到对方的龙身上后,火球会穿过龙,沿着刚才的方向继续飞行。保证此后种族 $F_j$ 不会再次敌视种族 $G_j$。

火球会烧坏道路。对于给出的 $Q$ 种冲突,求其中有多少个火球会烧坏道路。

输入格式

第一行有两个整数 $N, M$ ,用空格分隔。

在接下来的 $N$ 行中,第 $i$ 行 $(1\le i\le N)$ 有三个整数 $A_i, B_i, C_i$ 。

第 $N + 2$ 行有四个整数 $D_1, E_1, D_2, E_2$ ,用空格分隔。

第 $N + 3$ 行有一个整数 $Q$ 。

在接下来的 $Q$ 行中,第 $j$ 行 $(1\le i\le Q)$ 有两个用空格分隔的整数 $F_j, G_j$ 。

输出格式

输出共 $Q$ 行,每行一个整数,表示在第 $j$ 种冲突之中,有多少个火球会烧坏道路。

样例一

input

4 2
0 1 1
0 -1 1
1 2 2
-6 1 2
-2 0 2 0
2
1 2
2 1

output

1
2

explanation

在第一种冲突中:

  • 2 号龙向 3 号龙发射的火球会烧坏道路。

  • 1 号龙向 3 号龙、1 号龙向 4 号龙、2 号龙向 4 号龙发射的火球不会烧坏道路。

在第二种冲突中:

  • 3 号龙向 1 号龙、3 号龙向 2 号龙发射的火球会烧坏道路。

  • 4 号龙向 1 号龙、4 号龙向 2 号龙发射的火球不会烧坏道路。

样例二

input

3 2
-1000000000 -1 1
-999999998 -1 1
0 0 2
999999997 1 999999999 1
1
1 2

output

1

样例三

input

6 3
2 -1 1
1 0 1
0 3 2
2 4 2
5 4 3
3 9 3
0 0 3 3
6
1 2
1 3
2 1
2 3
3 1
3 2

output

4
2
4
0
2
1

数据范围与提示

$\text{Subtask 1 (15 points) }N\le 3000$。

$\text{Subtask 2 (45 points) }Q\le 100$。

$\text{Subtask 3 (40 points)}$ 无额外限制。

对于所有数据,$2\le M\le N\le 3\times 10^4, 1\le Q\le 10^5$ ,所有点的横坐标绝对值、纵坐标绝对值均 $\le 10^9$ ,所有点互不相同,没有三点共线,

时间限制:$3\texttt{s}$

空间限制:$256\texttt{MB}$