描述

给定一个平面上nn条水平直线和mm条垂直直线,它们相交形成nnmm列的网格,从上到下第rr条水平直线和从左到右第cc条垂直直线之间的交点称为格点(r,c)(r,c)。网格中任意两个水平或垂直相邻的格点之间的线段称为一条边,每条边有一个非负整数边权。
进行TT次询问,每次询问形式如下:
给出kkTT次询问的kk可能不同)个附加点,每个附加点位于一条从网格边缘向外出发的射线上。所有从网格边缘向外出发的射线按左上-右上-右下-左下-左上的顺序依次编号为112n+2m2n+2m,如下图:
enter image description here
对于每次询问,不同附加点所在的射线互不相同。每个附加点和最近的格点之间的线段也称为一条边,也有非负整数边权(注意,在角上的格点有可能和两个附加点同时相连)。
给定每个附加点的颜色(黑色或者白色),请你将网格内每个格点的颜色染成黑白二者之一,并使得所有两端颜色不同的边的边权和最小。请输出这个最小的边权和。

输入

第一行,三个正整数n,m,Tn,m,T,分别表示水平、垂直直线的数量,以及询问次数。
接下来n1n-1行,每行mm个非负整数。其中第ii行的第jj个非负整数x1i,j{x_1}_{i,j}表示(i,j)(i,j)(i+1,j)(i+1,j)间的边权。
接下来nn行,每行m1m-1个非负整数。其中第ii行的第jj个非负整数x2i,j{x_2}_{i,j}表示(i,j)(i,j)(i,j+1)(i,j+1)间的边权。
接下来依次输入TT组询问。第ii组询问开头为一行一个正整数kik_i表示这次询问附加点的总数。接下来kik_i行每行三个非负整数。其中第jj行依次为x3i,j,pi,j,ti,j{x_3}_{i,j},p_{i,j},t_{i,j}表示第jj个附加点和相邻格点之间的边权、所在的射线编号以及附加点颜色(00为白色,11为黑色)。保证同一组询问内pi,jp_{i,j}互不相同。
每行的多个整数由空格分隔。

输出

输出TT行,第ii行输出一个非负整数,表示第 次询问染色之后两端颜色不同的边权和的最小值。

样例输入
2 3 1
9 4 7
3 8
10 5
2
19 3 1
17 9 0

样例输出
12
提示

最优方案:(1,3),(1,2),(2,3)(1,3),(1,2),(2,3)为黑色;(1,1),(2,1),(2,2)(1,1),(2,1),(2,2)为白色。
数据范围与提示

测试点编号 dd dd
1~2 5 50
3~5 18 2
6~8 18 50
9~10 100 2
11~12 100 50
13~16 500 2
17~20 500 50

对于所有数据,2n,m500,1T50,1kimin{2(n+m),50},1Ti=1ki50,0x106,1p2(n+m),t{0,1}2\leqslant n,m\leqslant 500,1\leqslant T\leqslant 50,1\leqslant k_i\leqslant min\{2(n+m),50\},1\leqslant \sum _{T}^{i=1} k_i\leqslant 50,0\leqslant x\leqslant 10^6,1\leqslant p\leqslant 2(n+m),t\in \{0,1\}
保证对于每个i[1,T]i \in [1,T]pi,jp_{i,j}互不相同。