当前位置: 首页 > news >正文

LGP7916 [CSP-S 2021] 交通规划 学习笔记

LGP7916 [CSP-S 2021] 交通规划 学习笔记

Luogu Link

前言

仔细读了十遍题面,硬是一个字都没和交通规划扯上关系,很有可能是出题人编了一个故事,发现编不下去了。——\(\texttt{OMG-WC}\)

题意简述

有一个 \(n\times m\) 个点的网格图。对于这个网格图的最外侧,有些网格线会延伸一格到一个附加点上。所有边均有非负整数边权。

给定每个附加点的颜色(橙或蓝),你可以随意给网格内那 \(n\times m\) 个点染色,染色方案的代价为所有两端点异色的边的边权和。问最小的代价。

\(2\le n,m\le 500\)\(T\le 50\)\(k_i\) 均在合法范围内。

特别地,有 \(45\text{pts}\) 部分分满足 \(k_i\le 2\)

做法解析

不妨从 \(k_i\le 2\) 的部分分考虑。显然,如果附加点颜色全部一致,那答案就是 \(0\)。那么,当 \(k_i=2\) 且两个附加点异色时,答案是一个最小割。参考 \(\texttt{LGP4001}\)\(\texttt{LGP2604}\) 等。

那么 \(k_i>2\) 的时候呢?此时的答案形态……。

我们发现,如果两个相邻的附加点颜色一致,那它们之间肯定没有隔阂(就是必然处于一个同色连通块中)。

pVf8Abj.png

所以我们不妨把相同颜色的点“缩在一起”,然后再次从转化为对偶图最短路的视角来考虑。我们发现此时最小割之和在对偶图上表现为:若干个源汇点(被分为两种颜色,相邻则异色)需要和异色点完成两两的括号匹配,每一对匹配的代价为我们在对偶图上跑出来的最短路,这样的代价和。

pVf8VVs.png

你可能会问:括号匹配肯定是偶数个点做,为什么一定有偶数个对偶图上的源汇点呢?答:因为对于原图来说最外侧同色的连续段肯定为偶数。连续段如果是奇数等价于必有两段相邻且同色,那么它们应该被缩成一段。

所以原理就是这样。你求出这些对偶图上异色源汇点两两的最短路之后,跑一个 \(O(k^3)\) 的括号匹配 \(\texttt{DP}\) 即可。

代码实现


http://www.rkmt.cn/news/5413.html

相关文章:

  • 详细介绍:【Kubernetes】常见面试题汇总(十四)
  • 教育行业API安全最佳实践:全知科技以国家标准引领数据防护新范式
  • Qt处理USB摄像头开发说明与QtMultimedia与V4L2融合应用
  • 拾忆录
  • 从零搭建RAG应用:跳过LangChain,掌握文本分块、向量检索、指代消解等核心技术实现
  • python高阶技巧
  • CSS纯文本渐变动效
  • Redssion
  • 提升系统可靠性:Air8000多串口硬件设计的黄金法则
  • 20250915笔记
  • enumerate函数
  • HyperWorks许可激活
  • OpenStack Nova instance 常见操作
  • 线性规划
  • 伪代码学习总结
  • 麒麟
  • 多品牌摄像机视频平台EasyCVR海康大华宇视视频平台统一接入方案
  • ubuntu安装mysql矩阵
  • 043-WEB攻防-PHP应用SQL注入符号拼接请求方法HTTP头JSON编码类
  • 玻璃2601
  • 2025 ICPC 网络赛2 E
  • 西电微机原理与接口技术笔记总结
  • Mysql查找含字符串表字段
  • 真正的元推理,不需要人类的认可,恰恰是人类追求元推理,只有元推理才能彻底解放人类
  • 西电微机原理-第三章 Intel处理器指令系统及汇编语言(5)
  • 西电微机原理-第五章 存储技术
  • OpenStack Cinder 创建卷
  • 西电微机原理-第二章 Intel单核处理器
  • 二叉树的迭代遍历(非递归)
  • 今日流水账-2025年9月15日