【洛谷 P1902】 刺杀大使

126人阅读 评论(0) 收藏 举报
分类:

题目描述

伊朗伊斯兰革命卫队(某恐怖组织)正在策划一起刺杀行动,他们的目标是沙特驻美大 使朱拜尔。他们来到了沙特驻美使馆,准备完成此次刺杀,要进入使馆首先必须通过使馆前 的防御迷阵。

迷阵由 n*m 个相同的小房间组成,每个房间与相邻四个房间之间有门可通行。在第 n 行的 m 个房间里有 m 个机关,这些机关必须全部打开才可以进入大使馆。而第 1 行的 m 个 房间有 m 扇向外打开的门,是迷阵的入口。除了第 1 行和第 n 行的房间外,每个房间都被 使馆的安保人员安装了激光杀伤装置,将会对进入房间的人造成一定的伤害。第 i 行第 j 列 造成的伤害值为 p[i][j](第 1 行和第 n 行的 p 值全部为 0)。

现在伊斯兰革命卫队打算以最小伤害代价进入迷阵,打开全部机关,显然,他们可以选 择任意多的人从任意的门进入,但必须到达第 n 行的每个房间。一个士兵受到的伤害值为他 到达某个机关的路径上所有房间的伤害值中的最大值,整个部队受到的伤害值为所有士兵的 伤害值中的最大值。现在,这个恐怖组织掌握了迷阵的情况,他们需要提前知道怎么安排士 兵的行进路线可以使得整个部队的伤害值最小。

输入输出格式

输入格式:
第一行有两个整数 n,m,表示迷阵的大小。

接下来 n 行,每行 m 个数,第 i 行第 j 列的数表示 p[i][j]。

输出格式:
输出一个数,表示最小伤害代价。

输入输出样例

输入样例#1:
4 2
0 0
3 5
2 4
0 0
输出样例#1:
3
说明

50%的数据,n,m<=100;

100%的数据,n,m<=1000,p[i][j]<=1000。

最大值中的最小?
二分。

整张图,点权,无边权?
BFS。

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
using namespace std;
const int MAXN = 1001;
int dx[] = {0,1,0,-1};
int dy[] = {1,0,-1,0};
int n,m,num[MAXN][MAXN];
int l,r,used[MAXN][MAXN];
bool flag = false;
int ans = 2333;

bool out(int x,int y){
    if(x < 1 || y < 1 || x > n || y > m || used[x][y]) return false;
    else return true;
}

void dms(int x,int y,int p){
    if(x == n) {flag = true; return;}
    for(int i = 0; i < 4; i ++){
        int tx = dx[i] + x;
        int ty = dy[i] + y;
        if(!out(tx,ty)) continue;
        if(num[tx][ty] > p) continue;
        used[tx][ty] = true;
        dms(tx,ty,p);
        if(flag) return;
    }
}

int main(){
    scanf("%d %d",&n,&m);
    for(int i = 1; i <= n; i ++)
        for(int j = 1; j <= m; j ++)
            scanf("%d",&num[i][j]);

    l = 1,r = 2333,ans = 2333;
    while(l <= r){
        memset(used,0,sizeof(used));
        int mid = (l + r) >> 1; flag = false;
        dms(1,1,mid);
        if(flag)    r = mid - 1,ans = min(mid,ans);
        else l = mid + 1;
    }
    printf("%d\n",ans);
    return 0;
}
查看评论

洛谷 P1902 刺杀大使

http://www.studyai.com/article/fe08a030
  • loi_lxt
  • loi_lxt
  • 2017-10-21 19:08:03
  • 105

[洛谷P1902]刺杀大使

题目←总觉得spfa一脸可做的样子然而过不了 于是乖乖打了二分+验证#include #include #include #include #include using namespace std;...
  • LOI_pingxing
  • LOI_pingxing
  • 2017-10-21 16:56:10
  • 69

洛谷P1902 刺杀大使(二分)

题目描述 伊朗伊斯兰革命卫队(某恐怖组织)正在策划一起刺杀行动,他们的目标是沙特驻美大 使朱拜尔。他们来到了沙特驻美使馆,准备完成此次刺杀,要进入使馆首先必须通过使馆前 的防御迷阵。 ...
  • Loi_black
  • Loi_black
  • 2017-10-21 18:31:18
  • 106

洛谷P1902 刺杀大使(二分答案+bfs验证)

题目描述伊朗伊斯兰革命卫队(某恐怖组织)正在策划一起刺杀行动,他们的目标是沙特驻美大 使朱拜尔。他们来到了沙特驻美使馆,准备完成此次刺杀,要进入使馆首先必须通过使馆前 的防御迷阵。迷阵由 n*m 个相...
  • Loi_feather
  • Loi_feather
  • 2017-10-21 16:06:40
  • 112

P1902 刺杀大使(BFS+二分答案)

P1902 刺杀大使(From:Luogu) 题目描述伊朗伊斯兰革命卫队(某恐怖组织)正在策划一起刺杀行动,他们的目标是沙特驻美大 使朱拜尔。他们来到了沙特驻美使馆,准备完成此次刺杀,要进入使馆首先...
  • Stockholm_Sun
  • Stockholm_Sun
  • 2017-10-17 21:48:49
  • 173

【洛谷1902】刺杀大使

题目描述伊朗伊斯兰革命卫队(某恐怖组织)正在策划一起刺杀行动,他们的目标是沙特驻美大 使朱拜尔。他们来到了沙特驻美使馆,准备完成此次刺杀,要进入使馆首先必须通过使馆前 的防御迷阵。迷阵由 n*m 个相...
  • Hall_Of_Fame_
  • Hall_Of_Fame_
  • 2017-10-21 21:17:59
  • 59

【NOIP2013模拟】刺杀大使 题解

原题Description伊朗伊斯兰革命卫队(某恐怖组织)正在策划一起刺杀行动,他们的目标是沙特驻美大使朱拜尔。他们来到了沙特驻美使馆,准备完成此次刺杀,要进入使馆首先必须通过使馆前的防御迷阵。迷阵一...
  • lijf2001
  • lijf2001
  • 2016-06-20 20:19:17
  • 491

【NOIP 模拟题】刺杀大使(二分答案+并查集)

箫轻响、恍若惊鸿掠影
  • reverie_mjp
  • reverie_mjp
  • 2016-08-28 16:59:22
  • 434

刺杀大使 解题报告

这道题应该说是非常好的一道题,题意大致是在一个矩阵中寻找一条从最下面一行到最上面一行经过最大的数最小的一条路。时限是2s。 看到这题第一直觉DP,但发现DP方程可以互相转移,于是DP变成了图论。。于...
  • TA201314
  • TA201314
  • 2015-01-03 13:52:48
  • 839

刺杀大使{未完成}

刺杀大使 (murder.pas/c/cpp) 【问题描述】 伊朗伊斯兰革命卫队(某恐怖组织)正在策划一起刺杀行动,他们的目标是沙特驻美大使朱拜尔。他们来到了沙特驻美使馆,准备完成此...
  • u012688783
  • u012688783
  • 2013-11-04 14:12:03
  • 811
    个人资料
    等级:
    访问量: 7万+
    积分: 2881
    排名: 1万+
    %%%