BZOJ 1001 狼捉兔子

Description

现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的,而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一个网格的地形:

 

左上角点为(1,1),右下角点为(N,M)(上图中N=4,M=5).有以下三种类型的道路 1:(x,y)<==>(x+1,y) 2:(x,y)<==>(x,y+1) 3:(x,y)<==>(x+1,y+1) 道路上的权值表示这条路上最多能够通过的兔子数,道路是无向的. 左上角和右下角为兔子的两个窝,开始时所有的兔子都聚集在左上角(1,1)的窝里,现在它们要跑到右下解(N,M)的窝中去,狼王开始伏击这些兔子.当然为了保险起见,如果一条道路上最多通过的兔子数为K,狼王需要安排同样数量的K只狼,才能完全封锁这条道路,你需要帮助狼王安排一个伏击方案,使得在将兔子一网打尽的前提下,参与的狼的数量要最小。因为狼还要去找喜羊羊麻烦.

Input

第一行为N,M.表示网格的大小,N,M均小于等于1000.接下来分三部分第一部分共N行,每行M-1个数,表示横向道路的权值. 第二部分共N-1行,每行M个数,表示纵向道路的权值. 第三部分共N-1行,每行M-1个数,表示斜向道路的权值. 输入文件保证不超过10M

Output

输出一个整数,表示参与伏击的狼的最小数量.

Sample Input

3 4
5 6 4
4 3 1
7 5 3
5 6 7 8
8 7 6 5
5 5 5
6 6 6

Sample Output

14

HINT

Source

 

这个刚看一眼以为是道网络流裸题(ISAP 跑无向图最小割),但看数据范围马上枪毙。

后来r_64大神犇教了一个平面图转对偶图求最小割的方法,时间复杂度是跑最短路的。

具体做法如下:

先将源点与汇点连接一条边,此边不与其他任何边相交,再将所有的平面surface看做一个点,平面与平面的边界看做一条边,边权即为边界的边权(之前连的除外,边权inf)。仔细想想,原图的最小割即为两个外围的大平面的最短路。

代码如下:

 1 #include<cstring>
 2 #include<queue>
 3 #include<cstdio>
 4 #include<cstdlib>
 5 using namespace std;
 6 
 7 #define maxn 1010
 8 #define source 0
 9 #define sink (2*(n-1)*(m-1)+1)
10 const int inf = 1<<30;
11 int side[maxn*maxn*2],toit[maxn*maxn*6],n,m,dis[maxn*maxn*2];
12 int cnt = 1,next[maxn*maxn*6],len[maxn*maxn*6];
13 bool in[maxn*maxn*2];
14 
15 inline void add(int a,int b,int c)
16 {
17     toit[++cnt] = b;
18     next[cnt] = side[a];
19     side[a] = cnt;
20     len[cnt] = c;
21 }
22     
23 inline void ins(int a,int b,int c)
24 {
25     add(a,b,c); add(b,a,c);
26 }
27 
28 inline void build()
29 {
30     int a,i,j;
31     for (i = 1;i <= n;++i)
32     {
33         for (j = 1;j < m;++j)
34         {
35             scanf("%d",&a);
36             int up,down;
37             if (i == 1) up = sink;
38             else up = (i-2)*(m-1)+j;
39             if (i == n) down = source;
40             else down = (n-1)*(m-1)+(i-1)*(m-1)+j;
41             ins(up,down,a);
42         }
43     }
44     for (i = 1;i < n;++i)
45         for (j = 1;j <= m;++j)
46         {
47             scanf("%d ",&a);
48             int le,ri;
49             if (j == 1) le = source;
50             else le = (n-1)*(m-1)+(i-1)*(m-1)+j-1;
51             if (j == m) ri = sink;
52             else ri = (i-1)*(m-1)+j;
53             ins(le,ri,a);
54         }
55     for (i = 1;i < n;++i)
56         for (j = 1;j < m;++j)
57         {
58             scanf("%d ",&a);
59             int le,ri;
60             le = (i-1)*(m-1)+j;
61             ri = (i-1)*(m-1)+(n-1)*(m-1)+j;
62             ins(le,ri,a);
63         }
64 }
65 
66 inline int spfa()
67 {
68     queue <int> team;
69     in[source] = true; memset(dis,0x7,sizeof(dis));
70     dis[source] = 0; team.push(source);
71     int now,i;
72     while (!team.empty())
73     {
74         now = team.front(); team.pop();
75         for (i = side[now];i;i = next[i])
76             if (dis[toit[i]] > dis[now] + len[i])
77             {
78                 dis[toit[i]] = dis[now] + len[i];
79                 if (!in[toit[i]])
80                     in[toit[i]] = true,team.push(toit[i]);
81             }
82         in[now] = false;
83     }
84     return dis[sink];
85 }
86 
87 int main()
88 {
89     freopen("1001.in","r",stdin);
90     freopen("1001.out","w",stdout);
91     scanf("%d %d",&n,&m);
92     build();
93     printf("%d\n",spfa());
94     fclose(stdin); fclose(stdout);
95     return 0;
96 }

 

转载于:https://www.cnblogs.com/mmlz/p/4191431.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/472590.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

可视化工具Navicat for MySQL-操作三

五、备份和还原MySQL数据库 在数据库的管理中&#xff0c;备份和还原是必须做认真做的事情&#xff0c;如果疏忽或者做粗糙了&#xff0c;那么一旦数据库故障后果不堪设想&#xff0c;所以Navicat同样也有备份和还原的功能&#xff0c;相比较创建功能&#xff0c;其备份功能则…

如何在python中打开文件_Python文件处理:创建、打开、追加、读、写

在Python中&#xff0c;不需要导入外部库来读取和写入文件。Python为创建、写入和读取文件提供了内置的函数。 在本文中&#xff0c;我们将学习 如何创建文本文件 如何将数据附加到文件中 如何读取文件 如何逐行读取文件 Python中的文件模式 如何创建文本文件 使用Python&#…

天池 在线编程 排名查询

文章目录1. 题目2. 解题1. 题目 描述 给一个二维数组scores表示每个学生的各科成绩&#xff0c;求出学生中总成绩排名第K的索引。 如果成绩一样&#xff0c;越早出现的排名越高。 0 < scores[i][j] < 100 示例&#xff1a; 输入: scores: [[90, 80, 70], [90, 90, 90],…

matlab处理亮度不均匀,校正亮度不均匀问题并分析前景对象

预处理图像将图像读入工作区。I imread(rice.png);imshow(I)图像中心的背景亮度比底部亮度高。预处理图像&#xff0c;使背景亮度更加均匀。第一步&#xff0c;使用形态学开运算删除所有前景(米粒)。开运算会删除无法完全包含结构元素的小对象。定义半径为 15 的盘形结构元素&…

LeetCode 1797. 设计一个验证系统(map)

文章目录1. 题目2. 解题1. 题目 你需要设计一个包含验证码的验证系统。 每一次验证中&#xff0c;用户会收到一个新的验证码&#xff0c;这个验证码在 currentTime 时刻之后 timeToLive 秒过期。 如果验证码被更新了&#xff0c;那么它会在 currentTime &#xff08;可能与之前…

git add remote_使用git管理嵌入式软件版本

点击上方蓝字关注我哦&#xff5e;你现在的Keil工程的版本控制是怎么管理的&#xff1f;可能有些人的做法是发布一个版本软件后将代码打一个包保存起来&#xff0c;作为此版本的备份。有一种常见的情况&#xff0c;当开始一项新功能的开发&#xff0c;并且最终的效果不理想老板…

xshell 6 连接debian系统拒绝了密码_Xshell中操作Linux的常用命令,你知道几个?

作为IT人员&#xff0c;想必都知道Linux是一套免费使用和自由传播的类Unix操作系统&#xff0c;是一个基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。Xshell作为专业的终端模拟器&#xff0c;可以用来登录Linux&#xff0c;从而通过命令来控制Linux系统&…

LeetCode 1798. 你能构造出连续值的最大数目

文章目录1. 题目2. 解题1. 题目 给你一个长度为 n 的整数数组 coins &#xff0c;它代表你拥有的 n 个硬币。 第 i 个硬币的值为 coins[i] 。如果你从这些硬币中选出一部分硬币&#xff0c;它们的和为 x &#xff0c;那么称&#xff0c;你可以 构造 出 x 。 请返回从 0 开始&…

分别用邻接矩阵和邻接表实现图的深度优先遍历和广度优先遍历_数据结构与算法学习笔记:图...

图&#xff1a;图结构区别于线性结构和树型结构&#xff0c;区别可见下图逻辑上的图(graph)结构由顶点(vertex)和边(edge)组成。一个图结构G包含顶点集合V和边集合E&#xff0c;任何两个顶点之间可以有一个边表示两者的关系。对于一个存在的G&#xff0c;V不可以为空集&#xf…

人类附身机器人获得永生_脑机接口先驱尼古莱利斯:人类无法实现数字永生

科幻作品中的意念控制、心灵感应&#xff0c;甚至数字“永生”&#xff0c;会通过脑机接口技术得以实现吗&#xff1f;脑机接口技术先驱者之一、杜克大学神经工程学教授米格尔尼古莱利斯(Miguel Nicolelis)表示&#xff0c;不可能。近日&#xff0c;尼古莱利斯在巴西家中与北京…

linux内核分成如下五个子系统,linux内核主要由5个子系统 Linux内核由哪几个子系统组成?...

1, Linux内核由哪几个子系统组成&#xff1f;Linux内核主要由五个子系统组成&#xff1a;进程调度&#xff0c;内存管理&#xff0c;虚拟文件系统&#xff0c;网络接口&#xff0c;进程间通信。1.进程调度(SCHED)&#xff1a;控制进程对CPU的访问。当需要选择下一个进程运行时&…

LeetCode 1799. N 次操作后的最大分数和(回溯 / 状态压缩DP)

文章目录1. 题目2. 解题2.1 错误解2.2 回溯超时解2.3 回溯通过2.4 状态压缩DP1. 题目 给你 nums &#xff0c;它是一个大小为 2 * n 的正整数数组。 你必须对这个数组执行 n 次操作。 在第 i 次操作时&#xff08;操作编号从 1 开始&#xff09;&#xff0c;你需要&#xff1…

pytorch argmax_轻松学Pytorch使用ResNet50实现图像分类

点击上方蓝字关注我们微信公众号&#xff1a;OpenCV学堂关注获取更多计算机视觉与深度学习知识Hello大家好&#xff0c;这篇文章给大家详细介绍一下pytorch中最重要的组件torchvision&#xff0c;它包含了常见的数据集、模型架构与预训练模型权重文件、常见图像变换、计算机视觉…

LeetCode 1800. 最大升序子数组和

文章目录1. 题目2. 解题1. 题目 给你一个正整数组成的数组 nums &#xff0c;返回 nums 中一个 升序 子数组的最大可能元素和。 子数组是数组中的一个连续数字序列。 已知子数组 [numsl, numsl1, ..., numsr-1, numsr] &#xff0c;若对所有 i&#xff08;l < i < r&a…

html使用js的变量_2、温故而知新,再学一遍JavaScript-html中如何使用JS

温故而知新&#xff0c;再学一遍JavaScripthtml中使用JavaScript有两种方式&#xff1a;通过中使用src属性引入外部JS文件,同时又在其内部嵌入JavaScript 代码&#xff0c;则嵌入的代码会被忽略。关于”字符串当浏览器遇到字符串""时就会认为代码块已经结束&#xff…

修改字段类型_PostgreSQL 关于字段类型的修改 谣言与止谣

​PostgreSQL 在9.2 之前是要面临一个指责&#xff0c;就是在更改字段类型的时候带来的不堪&#xff0c;假象你有100万行的数据&#xff0c;其中一个字段是varchar(20) ,你想将其更改为 varhcar(30), 这可能就要造成一个灾难&#xff0c;熟悉postgresql 原理的人们&#xff0c;…

用户 'IIS APPPOOL\***' 登录失败(转载)

用户 IIS APPPOOL\DefaultAppPool 登录失败。 我在windows8中安装了iis之后添加了我做的网站打开之后提示用户 IIS APPPOOL\DefaultAppPool 登录失败。 我再vs2010中能正常运行 最佳答案 这是设置iis应用程序池的设置问题。我就遇到了这样的问题。 比如我的网站取名myweb…

完全相同的4个小矩形如图所示放置_吸睛!矩形在PPT中的创意表现

如何在PPT中表现出光效来&#xff1f;这是很多人在制作PPT时都可能会面临的问题&#xff0c;大多数人的常规做法就是在许多素材网站中直接寻找&#xff0c;比如在花瓣中直接搜索"光效"&#xff0c;我们可以得到以下结果&#xff1a;这些光效PNG文件可以直接用在我们的…

LeetCode 1801. 积压订单中的订单总数(map)

文章目录1. 题目2. 解题1. 题目 给你一个二维整数数组 orders &#xff0c;其中每个 orders[i] [pricei, amounti, orderTypei] 表示有 amounti 笔类型为 orderTypei 、价格为 pricei 的订单。 订单类型 orderTypei 可以分为两种&#xff1a; 0 表示这是一批采购订单 buy1 …

quantaxis 云服务器_量化金融策略开源框架:QUANTAXIS

简介&#xff1a; QUANTAXIS量化金融策略框架,是一个面向中小型策略团队的量化分析解决方案&#xff0c;是一个从数据爬取、清洗存储、分析回测、可视化、交易复盘的本地一站式解决方案。QUANTAXIS量化金融策略框架,是一个面向中小型策略团队的量化分析解决方案&#xff0c;是一…