130. Blink

题目

描述

在一场DOTA战争中,影魔终于获得获得了传说中的闪烁匕首,也就用了闪烁技能,但是闪烁有个缺陷——我们把地图看做N*N的点阵,假设影魔在点(x,y)上,那么闪烁只能让他到达(x±2,y±2)的四个点,前提是这个点存在并且上面没有石头或者树这种障碍。可恶的是,敌方的英雄早已在地图上布下了减速陷阱,如果踩中陷阱,将会让他减速,但陷阱也会消失!现在影魔要从敌人的包围中逃脱,即从左上顶点(1,1)逃到右下顶点(N,N),请你帮他算出逃脱所需的最短时间!
注:闪烁一次花费1s,踩中陷阱停滞1s,当然,影魔也可以选择向上下左右四个方向移动1个单位,每次移动花费1s。

输入

第一行包含一个数N(2<=N<=50)
接下来的N行表示N*N的地图。其中0表示空地,1表示障碍,2表示陷阱,保证(1,1)和(N,N)为0

输出

输出逃脱花费的最短时间
如果无法逃脱,输出”Impossible”

输入样例
4
0000
0000
0000
0000
输出样例
3

思路分析

BFS,区别在于陷阱需要+1。

【我的代码】

#include <queue>
#include <cstring>

typedef struct pos {
    int x, y, cnt;
}pos;

int directions[8][2] = {{2, 2}, {2, -2}, {-2, 2}, {2, -2}, {1, 0}, {-1, 0}, {0, 1}, {0, -1}};
int n;
queue<pos> maze;
char map_char;
int map[51][51] = {0};
int visited[51][51] = {0};
int cnt[51][51] = {0};
int min_step = 999999;

int bfs()
{
    int step = 1;
    while (maze.size())
    {
        pos top_item = maze.front();
        maze.pop();
        if (map[top_item.x][top_item.y] == 1 || top_item.x < 1 || top_item.x > n || top_item.y < 1 || top_item.y > n || (visited[top_item.x][top_item.y] == 1 && top_item.cnt >= cnt[top_item.x][top_item.y]))
            continue;
        cnt[top_item.x][top_item.y] = top_item.cnt;
        int tcnt = top_item.cnt + 1;
        if (map[top_item.x][top_item.y] == 2) {
            tcnt++;
        }
        for (int i = 0; i < 8; i++)
        {
            pos new_item = {directions[i][0] + top_item.x, directions[i][1] + top_item.y, tcnt};
            maze.push(new_item);
        }
        visited[top_item.x][top_item.y] = 1;
        step++;
    }
}

int main(){
    cin >> n;
    for (int i = 1; i <= n; i++)
    {
        for (int j = 1; j <= n; j++)
        {
            cin >> map_char;
            map[i][j] = int(map_char) - 48;
        }
    }
    pos begin = {1, 1, 0};
    maze.push(begin);
    bfs();
    if (cnt[n][n])
        cout << cnt[n][n] << endl;
    else
        cout << "Impossible" << endl;
    return 0;
}
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,997评论 6 502
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,603评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,359评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,309评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,346评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,258评论 1 300
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,122评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,970评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,403评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,596评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,769评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,464评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,075评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,705评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,848评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,831评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,678评论 2 354

推荐阅读更多精彩内容

  • 树形动态规划,顾名思义就是树+DP,先分别回顾一下基本内容吧:动态规划:问题可以分解成若干相互联系的阶段,在每一个...
    Mr_chong阅读 1,486评论 0 2
  • 1. file n. 文件;v. 保存文件2. command n. 命令指令3. use v. 使用用途4. p...
    喵呜Yuri阅读 751评论 0 4
  • 个人学习批处理的初衷来源于实际工作;在某个迭代版本有个BS(安卓手游模拟器)大需求,从而在测试过程中就重复涉及到...
    Luckykailiu阅读 4,718评论 0 11
  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 3,341评论 0 2
  • 最近,银行卡、微信、支付宝、钱包四大皆空的吃土青年又多了一个更为响亮的名号:隐形贫困人口。 顾名思义,“隐形贫困人...
    网易王三三阅读 1,607评论 0 6