题目名称 3622. [CSP 2021S]交通规划
输入输出 2021traffic.in/out
难度等级 ★★★★
时间限制 3000 ms (3 s)
内存限制 512 MiB
测试数据 20
题目来源 Gravatarsyzhaoss 于2021-10-23加入
开放分组 全部用户
提交状态
分类标签
网络流 NOIP/CSP
分享题解
通过:0, 提交:17, 通过率:0%
Gravatarop_组撒头屯 65 23.293 s 14.91 MiB C++
Gravatarsywgz 60 6.452 s 43.88 MiB C++
Gravatarop_组撒头屯 40 2.972 s 14.23 MiB C++
Gravatarsywgz 20 24.781 s 40.07 MiB C++
Gravatarsywgz 10 4.159 s 8.63 MiB C++
Gravatar冷月星云 0 0.000 s 0.00 MiB C++
Gravatarqqqqq 0 0.000 s 0.00 MiB C++
Gravatar荒之梦殇 0 0.009 s 5.85 MiB C++
Gravatarop_组撒头屯 0 0.012 s 18.39 MiB C++
Gravatar00000 0 1.120 s 7.51 MiB C++
本题关联比赛
近5年noip/csp题目回顾
关于 交通规划 的近10条评论(全部评论)

3622. [CSP 2021S]交通规划

★★★★   输入文件:2021traffic.in   输出文件:2021traffic.out   简单对比
时间限制:3 s   内存限制:512 MiB

【题目描述】

给定一个平面上$n$条水平直线和$m$条垂直直线,它们相交形成$n$行$m$列的网格,从上到下第$r$条水平直线和从左到右第$c$条垂直直线之间的交点称为格点$(r,c)$。网格中任意两个水平或垂直相邻的格点之间的线段称为一条边,每条边有一个非负整数边权。

进行$T$次询问,每次询问形式如下:

给出$k$($T$次询问的$k$可能不同)个附加点,每个附加点位于一条从网格边缘向外出发的射线上。所有从网格边缘向外出发的射线按左上-右上-右下-左下-左上的顺序依次编号为$1$到$2n+2m$,如下图:

对于每次询问,不同附加点所在的射线互不相同。每个附加点和最近的格点之间的线段也称为一条边,也有非负整数边权(注意,在角上的格点有可能和两个附加点同时相连)。

给定每个附加点的颜色(黑色或者白色),请你将网格内每个格点的颜色染成黑白二者之一,并使得所有两端颜色不同的边的边权和最小。请输出这个最小的边权和。

【输入格式】

第一行 3 个正整数$n,m,T$分别表示水平、垂直直线的数量,以及询问次数。

接下来$n-1$行,每行$m$个非负整数。其中第$i$行的第$j$个非负整数$x1_{i,j}$表示$(i,j)$和$(i + 1,j)$间的边权。

接下来$n$行,每行$m-1$个非负整数。其中第$i$行的第$j$个非负整数$x2_{1,j}$表示$(i,j)$和$(i,j + 1)$间的边权。

接下来依次输入$T$组询问。第$i$组询问开头为一行一个正整数$k_i$表示这次询问附加点的总数。接下来$k_i$行每行三个非负整数。其中第$j$行依次为$x3_{i,j},p_{i,j},t_{i,j}$表示第$i$个附加点和相邻格点之间的边权、所在的射线编号以及附加点颜色(0为白色,1为黑色)。保证同一组询问内$p_{i,j}$互不相同。

每行的多个整数由空格分隔。

【输出格式】

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

【样例1输入】

2 3 1
9 4 7
3 8
10 5
2
19 3 1
17 9 0

【样例1输出】

12

【样例1解释】

最优方案:$(1,3),(1,2),(2,3)$为黑色;$(1,1),(2,1),(2,2)$为白色。

【样例2/3/4/5】

下载

【数据规模与约定】

对于所有数据,$2\leq n,m\leq 500,1\leq T\leq 50,1\leq k\leq \min\{2(n+m),50\},1\leq \sum_{i=1}^Tk_i\leq 50,$ $0\leq x\leq 10^6,1\leq p\leq 2(n+m),t\in\{0,1\}$。

保证对于每个$i\in\{1,T\},p_{i,j}$互不相同。

【来源】

CSP2021 提高组 Task4