#L3791. 「ZJOI2008」无序运动

    ID: 3837 传统题 1000ms 256MiB 尝试: 1 已通过: 1 难度: 10 上传者: 标签>计算几何坐标变换离散化与扫描字符串KMP哈希和哈希表其他构造

「ZJOI2008」无序运动

题目描述

D 博士对物理有着深入的研究,经典物理、天体物理、量子物理都有着以他的名字命名的定理。最近 D 博士着迷于研究粒子运动的无规则性。对圣经深信不疑的他相信,上帝创造的任何事物必然是有序的、有理可循的,而不是无规则的、混沌的。

经过长时间的研究,D 博士找到了很多出现相当频繁的轨迹片断,他把这些轨迹片断储存在一个很大的数据库内。他需要你帮助他写一个程序,对于一个给出的粒子运动轨迹,统计数据库中每个轨迹片断的出现的次数。

为清楚起见,我们定义一个粒子的轨迹为二维平面上的一个点列 (p1,p2,,pn)(p_1, p_2, \dots, p_n)。点列 pp 的一个子列 [i,j][i, j] 定义为 pp 中一段连续的子序列 (pi,pi+1,,pj)(p_i, p_{i + 1}, \dots, p_j)。点列 PP 的一个子列 [u,v][u, v] 被称为点列 q=(q1,q2,,qvu+1)q = (q_1, q_2, \dots, q_{v - u + 1})pp 中的一次出现,当且仅当 qq 经过有限次的平移、旋转、翻转、放缩之后得到 qq^{\prime} 满足 [ q^{\prime}k = p{u + k - 1} \quad (k = 1, \dots, v-u+1)。 ]


输入格式

输入第一行两个整数 n,mn, m,分别描述待处理的粒子运动轨迹的点列大小与数据库内的轨迹片断个数。

接下来 mm 行依次给出每个轨迹片断。每行先是一个正整数 kk,表示该轨迹片断点列的长度。然后 2k2k 个整数,依次描述点列中的 kk 个点的横坐标与纵坐标。

接下来一行 2n2n 个整数,依次描述待处理的粒子运动轨迹的点列中 nn 个点的横坐标与纵坐标。

注:输入中的每条轨迹中任意相邻两点不会相同。


输出格式

输出应包含 mm 行,依次给出每个片段在待处理运动轨迹中的出现次数。


样例

输入

3 2
2 17 0 10 1
3 0 0 1 0 1 -1
0 0 1 0 1 1

输出

2
1

数据范围与提示

  • 对于 30%30\% 的数据,1n,m,k1001\le n, m, k\le100,片段总长度 500\le 500
  • 对于 50%50\% 的数据,1n,m,k1031\le n,m,k\le10^3,片段总长度 5×103\le5\times 10^3
  • 对于 100%100\% 的数据,满足 1n,k2×1051 \le n, k \le 2 \times 10^5,片段总长度 2×104\le 2 \times 10^4,所有点坐标绝对值均不大于 10410^4

对平面 X-Y 进行四种操作的解释

  • 平移:设平移向量为 (dx,dy)(d_x, d_y),则任意点 (x,y)(x, y) 平移后的结果为 (x+dx,y+dy)(x + d_x, y + d_y)
  • 旋转:设旋转角为 tt,则任意点 (x,y)(x, y) 旋转后的结果为 (xcostysint,xsint+ycost)(x \cos t - y \sin t, x \sin t + y \cos t)
  • 翻转:任意点 (x,y)(x, y) 翻转后的结果为 (x,y)(x, -y)
  • 放缩:设放缩比例为 ppp0p \ne 0),则任意点 (x,y)(x, y) 放缩后的结果为 (px,py)(px, py)