题目描述

1944 年,特种兵麦克接到国防部的命令,要求立即赶赴太平洋上的一个孤岛,营救被敌军俘虏的大兵瑞恩。瑞恩被关押在一个迷宫里,迷宫地形复杂,但幸好麦克得到了迷宫的地形图。

迷宫的外形是一个长方形,其南北方向被划分为 nnn 行,东西方向被划分为 mmm 列, 于是整个迷宫被划分为 n×m n \times mn×m 个单元。每一个单元的位置可用一个有序数对 (单元的行号, 单元的列号) 来表示。

南北或东西方向相邻的 222 个单元之间可能互通,也可能有一扇锁着的门,或者是一堵不可逾越的墙。迷宫中有一些单元存放着钥匙,并且所有的门被分成 ppp类, 打开同一类的门的钥匙相同,不同类门的钥匙不同。

大兵瑞恩被关押在迷宫的东南角,即 (n,m)(n,m)(n,m) 单元里,并已经昏迷。迷宫只有一个入口, 在西北角。也就是说,麦克可以直接进入 (1,1)(1,1)(1,1) 单元。

另外,麦克从一个单元移动到另一个 相邻单元的时间为 111,拿取所在单元的钥匙的时间以及用钥匙开门的时间可忽略不计。

试设计一个算法,帮助麦克以最快的方式到达瑞恩所在单元,营救大兵瑞恩。

输入格式

第一行有三个整数,分别表示 n,mn , mn,m, 的值。
第二行是一个整数kkk,表示迷宫中门和墙的总数。
第 i+2i+2i+2 行 (1≤i≤k)(1 \leq i \leq k )(1≤i≤k),有 555 个整数,依次为 xi1,yi1,xi2,yi2,gix _{i1},y_{i1},x_{i2},y_{i2},g_ix​i1​​,y​i1​​,x​i2​​,y​i2​​,g​i​​ :当 gi≥1g_i \geq1g​i​​≥1 时,表示 (xi1,yi1)(x_{i1},y_{i1})(x​i1​​,y​i1​​) 单元与 (xi2,yi2)(x_{i2},y_{i2})(x​i2​​,y​i2​​) 单元之间有一扇第 gig_ig​i​​ 类的门,

当 gi=0g_i = 0g​i​​=0 时, 表示 (xi1,yi1)(x_{i1},y_{i1})(x​i1​​,y​i1​​)单元与 (xi2,yi2)(x_{i2},y_{i2})(x​i2​​,y​i2​​) 单元之间有一堵不可逾越的墙。
第 k+3k+3k+3 行是一个整数 sss,表示迷宫中存放的钥匙总数。
第 k+3+jk+3+jk+3+j 行 (1≤j≤s)(1 \leq j \leq s)(1≤j≤s) ,有 333 个整数,依次为 xi1,yi1,qix_{i1},y_{i1},q_ix​i1​​,y​i1​​,q​i​​,表示第 jjj 把钥匙存放在 (xi1,yi1)(x_{i1},y_{i1})(x​i1​​,y​i1​​) 单元里,并且第 jjj 把钥匙是用来开启第 qiq_iq​i​​ 类门。
输入数据中同一行各相邻整数之间用一个空格分隔。

输出格式

输出麦克营救到大兵瑞恩的最短时间。如果问题无解,则输出 −1-1−1。

样例

样例输入

4 4 9
9
1 2 1 3 2
1 2 2 2 0
2 1 2 2 0
2 1 3 1 0
2 3 3 3 0
2 4 3 4 1
3 2 3 3 0
3 3 4 3 0
4 3 4 4 0
2
2 1 2
4 2 1

样例输出

14

数据范围与提示

  • ∣xi1−xi2∣+∣yi1−yi2∣=1,0≤gi≤p|x_{i1}-x_{i2}|+|y_{i1}-y_{i2}|=1, 0 \leq g_i \leq p∣x​i1​​−x​i2​​∣+∣y​i1​​−y​i2​​∣=1,0≤g​i​​≤p
  • 1≤qi≤p1\leq q_i \leq p1≤q​i​​≤p
  • n,m,p≤10, k<150n,m,p \leq 10,\ k < 150n,m,p≤10, k<150
建立分层图spfa,dis[i][j]表示现在拥有钥匙种类的01串表达为i时到大j点所花费的最小时间,那么如果u->v之间有一扇w种类的门,则判定条件为
(i&w==w),解决了这个spfa就行了。
#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<queue>
#include<math.h>
using namespace std;
const int maxm = 105;
const int maxn = 5005;
const int INF = 1000009;
int flag[maxm][maxm], key[maxm*maxm], dis[maxn][maxm];
int id[maxm][maxm], vis[maxm*maxm], head[maxm*maxm], map[maxm][maxm];
int dx[4] = { 0,0,1,-1 };
int dy[4] = { 1,-1,0,0 };
struct node
{int v, w, next;
}edge[maxm*maxm * 2];
struct point
{int x, v;point(int a, int b) :x(a), v(b) {}point() {}
};
int n, m, s, t, cnt;
void init()
{cnt = 0, s = 1, t = n*m;memset(head, -1, sizeof(head));memset(map, -1, sizeof(map));memset(key, 0, sizeof(key));
}
void add(int u, int v, int w)
{edge[cnt].v = v, edge[cnt].w = w;edge[cnt].next = head[u], head[u] = cnt++;
}
int bfs()
{queue<point>q;memset(dis, 0x3f, sizeof(dis));dis[1][s] = 0;q.push(point(1, s));while (!q.empty()){point now = q.front();q.pop();int u = now.v;dis[now.x | key[u]][u] = min(dis[now.x | key[u]][u], dis[now.x][u]);now.x |= key[u];for (int i = head[u];i != -1;i = edge[i].next){int v = edge[i].v;if ((now.x&edge[i].w) == edge[i].w){if (dis[now.x][v] > dis[now.x][u] + 1){dis[now.x][v] = dis[now.x][u] + 1;q.push(point(now.x, v));}}}}int ans = INF;for (int i = 1;i < maxn;i++)ans = min(ans, dis[i][t]);if (ans == INF) return -1;return ans;
}
int main()
{int  i, j, k, sum, p, len = 0;int x1, x2, y1, y2, z, u, v;scanf("%d%d%d%d", &n, &m, &p, &k);init();for (i = 1;i <= n;i++)for (j = 1;j <= m;j++)id[i][j] = ++len;for (i = 1;i <= k;i++){scanf("%d%d%d%d%d", &x1, &y1, &x2, &y2, &z);u = id[x1][y1], v = id[x2][y2];map[u][v] = map[v][u] = z;if (z) add(u, v, 1 << z), add(v, u, 1 << z);}scanf("%d", &k);for (i = 1;i <= k;i++){scanf("%d%d%d", &x1, &y1, &z);key[id[x1][y1]] |= 1 << z;}for (i = 1;i <= n;i++){for (j = 1;j <= m;j++){u = id[i][j];for (k = 0;k < 4;k++){int x = i + dx[k];int y = j + dy[k];v = id[x][y];if (map[u][v] == -1 && id[x][y])add(u, v, 1);}}}printf("%d\n", bfs());return 0;
}

「网络流 24 题」孤岛营救问题相关推荐

  1. 「网络流24题」 题目列表

    「网络流24题」 题目列表 序号 题目标题 模型 题解 1 飞行员配对方案问题 二分图最大匹配 <1> 2 太空飞行计划问题 最大权闭合子图 <2> 3 最小路径覆盖问题 二分 ...

  2. 「网络流24题」 12. 软件补丁问题

    「网络流24题」 12. 软件补丁问题 状压 DP,SPFA 转移. 没错,跟网络流没任何关系. b1.b2.f1.f2 都用二进制存下来,第 i 位表示是否有这个错误. 然后从每位都是 1 到 0 ...

  3. loj #6226. 「网络流 24 题」骑士共存问题

    #6226. 「网络流 24 题」骑士共存问题 题目描述 在一个 n×n\text{n} \times \text{n}n×n 个方格的国际象棋棋盘上,马(骑士)可以攻击的棋盘方格如图所示.棋盘上某些 ...

  4. liberOJ#6006. 「网络流 24 题」试题库 网络流, 输出方案

    #6006. 「网络流 24 题」试题库   题目描述 假设一个试题库中有 n nn 道试题.每道试题都标明了所属类别.同一道题可能有多个类别属性.现要从题库中抽取 m mm 道题组成试卷.并要求试卷 ...

  5. LibreOJ #6001. 「网络流 24 题」太空飞行计划 最大权闭合图

    #6001. 「网络流 24 题」太空飞行计划 内存限制:256 MiB时间限制:1000 ms标准输入输出 题目类型:传统评测方式:Special Judge 上传者: 匿名 提交提交记录统计讨论测 ...

  6. LOJ6001 - 「网络流 24 题」太空飞行计划

    原题链接 Description 有m(m≤50)个实验和n(n≤50)个仪器,做实验有报酬买仪器有花费.每个实验都需要一些仪器,求最大净收益(实验报酬−仪器花费),并输出一组方案. Solution ...

  7. LibreOJ 6004. 「网络流 24 题」圆桌聚餐 网络流版子题

    #6004. 「网络流 24 题」圆桌聚餐 内存限制:256 MiB时间限制:5000 ms标准输入输出 题目类型:传统评测方式:Special Judge 上传者: 匿名 提交提交记录统计讨论测试数 ...

  8. loj #6004. 「网络流 24 题」圆桌聚餐(最大流)

    #6004. 「网络流 24 题」圆桌聚餐 内存限制:256 MiB时间限制:5000 ms标准输入输出 题目类型:传统评测方式:Special Judge 上传者: 匿名 提交提交记录统计讨论测试数 ...

  9. 【线性规划与网络流24题】孤岛营救问题 分层图

    孤岛营救问题 Time Limit: 1 Sec  Memory Limit: 128 MB Description 1944年,特种兵麦克接到国防部的命令.要求马上赶赴太平洋上的一个孤岛,营救被敌军 ...

最新文章

  1. Java8简明学习之接口默认方法
  2. W/System.err: at android.view.ViewConfiguration.get(ViewConfiguration.java:369)
  3. ASP.NET MVC 3: Razor视图引擎中 @: 和text 语法【转载】
  4. [转载]jquery cookie的用法
  5. 《C++ Primer 第五版》(第5.1-5.6节) ——异常处理机制(try语句块,throw表达式和catch异常捕捉处理单元)
  6. 前端学习(2045)vue之电商管理系统电商系统之优化chainwebpack自定义打包入口
  7. 【AI视野·今日Robot 机器人论文速览 第三十一期】Fri, 15 Apr 2022
  8. matlab实验4图形的绘制,MATLAB编程与应用实验报告(三维图形绘制)
  9. Python+OpenCV图像处理之模糊操作
  10. LeetCode刷题(35)--Add Binary
  11. 如何在 Safari 下载 ZIP 文件后不自动解压?
  12. Delphi7 sn
  13. 应用wms仓库管理系统,提高第三方物流企业竞争力
  14. 计算坐标系中两个点之间的距离c语言,如何求坐标系中两点间的距离
  15. 游戏贪吃蛇计分c语言,C语言实现贪吃蛇游戏(命令行)
  16. 华为设备MAC地址配置命令
  17. mov和mp4格式哪个好_公文需带附件时,标准的格式排布
  18. 51单片机堆栈深入剖析(转)
  19. 安徽师范大学计算机学院在哪个校区,2021年安徽师范大学有几个校区,大一新生在哪个校区...
  20. linux 耳机设备文件,linux耳机

热门文章

  1. 鸿蒙系统与麒麟os,华为鸿蒙系统改名为麒麟OS
  2. redis redisson 分布式锁 WRONGTYPE Operation against a key holding the wrong kind of value
  3. SpringCloud进阶-Hystrix的熔断机制+Hystrix的工作流程
  4. Qt解决中文显示乱码问题
  5. 微软必应词典的调查与研究
  6. 【寻找最佳小程序】04期 :探访“小打卡”产品打磨细节及线下场景真实应用
  7. NYOJ283对称排序
  8. 视频怎么做成二维码扫描展示?在线视频生成二维码的技巧
  9. android 美团多渠道打包方案
  10. PPT立方体三面同色