*传送

求最小步数,bfs求解。因为题目要求可以走八个方向(上下左右和对角线),所以两个方位数组来找八个方向

  int dirx[9]={0,0,1,1,1,0,-1,-1,-1};

  int diry[9]={0,-1,-1,0,1,1,1,0,-1};

开一个结构体,表示当前节点的横纵坐标、步数、和它从哪个方向来。

  }nowid,nextid; 

vis数组记录当前节点是否向某一方向走过 vis[x][y][way]x表示横坐标,y表示纵坐标,way表示方向(方位数组的角标)

从当前节点,可以向某一方向直接跨越当前节点所表示节点个数,所以当前节点能走到的位置为

  nextid.x=nowid.x+dirx[i]*map[nowid.x][nowid.y];
    nextid.y=nowid.y+diry[i]*map[nowid.x][nowid.y];

判断下个位置是否在当前方向走过,是否越界,若位置合理,步数+1,标记走过,并记录方向(因为两次不能走同个方向),剩下的就和bfs的板子一模一样了

代码:

 #include <iostream>
 #include <algorithm>
 #include <cstdio>
 #include <queue>
 using namespace std;
 int n,m;
 ][];
 ][][];
 ;
 ]={,,,,,,-,-,-};
 ]={,-,-,,,,,,-};
 struct node{
     int x,y,step,way;
 }nowid,nextid;
 void bfs(int x,int y){
     queue<node> q;
     nowid.x=x,nowid.y=y,nowid.step=,nowid.way=-;
     q.push(nowid);
     while (!q.empty()){
         nowid=q.front();q.pop();
         if (nowid.x==m&&nowid.y==n){
             flag=;
             printf ("%d\n",nowid.step);
             return;
         }
         nextid=nowid;
         ;i <= ;i++){
             if (nowid.way!=i){
                 nextid.x=nowid.x+dirx[i]*map[nowid.x][nowid.y];
                 nextid.y=nowid.y+diry[i]*map[nowid.x][nowid.y];
                 &&nextid.x<=m&&nextid.y>=&&nextid.y<=n&&!vis[nextid.x][nextid.y][i]){
                     vis[nextid.x][nextid.y][i]=;
                     nextid.step=nowid.step+;
                     nextid.way=i;
                     q.push(nextid);
                 }
             }
         }
     }
 }
 int main(){
     scanf ("%d%d",&n,&m);
     ;i <= m;i++)
         ;j <= n;j++)
             scanf ("%d",&map[i][j]);
     bfs(,);
     if (!flag) cout<<"NEVER"<<endl;
     ;
 }

bfs--P1301 魔鬼之城的更多相关文章

  1. 洛谷 P1301 魔鬼之城

    P1301 魔鬼之城 题目描述 在一个被分割为N*M个正方形房间的矩形魔鬼之城中,一个探险者必须遵循下列规则才能跳跃行动.他必须从(1, 1)进入,从(N, M)走出:在每一房间的墙壁上都写了一个魔法 ...

  2. 洛谷P1301 魔鬼之城 题解

    想找原题请点击这里:传送门 题目描述 在一个被分割为N*M个正方形房间的矩形魔鬼之城中,一个探险者必须遵循下列规则才能跳跃行动.他必须从(, )进入,从(N, M)走出:在每一房间的墙壁上都写了一个魔 ...

  3. 洛谷P1301 魔鬼之城

    传送门啦 一道广度优先搜索的题目. 结构体含义: struct node{ int x,y,dir;//坐标,方向 int step;//当前步数 }; 方向的标号受上面定义的 $ dx[ ] , d ...

  4. vijos p1777 引水入城(bfs+贪心)

    引水入城   描述 在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个N行M列的矩形,其中每个格子都代表一座城市,每座城市都有一个海拔高度. 为了使 ...

  5. NOIP2010_T4_引水入城 bfs+贪心

    在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个 N 行 M 列的矩形,如上图所示,其中每个格子都代表一座城 市,每座城市都有一个海拔高度.为了使 ...

  6. 引水入城 2010年NOIP全国联赛提高组(bfs+贪心)

    1066 引水入城 2010年NOIP全国联赛提高组  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond     题目描述 Description 在一个遥远 ...

  7. luoguP1514 引水入城 题解(NOIP2010)(Bfs+贪心)

    P1514 引水入城  题目 #include<iostream> #include<cstdlib> #include<cstdio> #include<c ...

  8. NOIP2010引水入城[BFS DFS 贪心]

    题目描述 在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个N 行M 列的矩形,如上图所示,其中每个格子都代表一座城市,每座城市都有一个海拔高度. ...

  9. noip2010 引水入城 bfs+贪心

    如果能够实现,每个河边的城市对应的控制区域一定是一条线段. 所以直接bfs每个河边的城市,贪心线段的右端点 #include<cstdio> #include<cstring> ...

随机推荐

  1. IdentityServer4专题之四:Authorization Endpoint、Token Endpoint、scope、Access Token和Refresh Token、授权服务器发生错误

    1.Authorization Endpoint 它是与用户交互的端点,用户在此进行为客户端应用授权的操作,即authorization grant 2.Token Endpoint 端点,就是一个w ...

  2. JAVA地址栏重写很详细

    这几天蛋疼.看看别人url重写是怎么搞的..1.解释下什么事url重写,以及它的优缺点: URL重写,其实就是把带一大堆参数的url,变成一个看上去很规矩的url.例:/viewthread.jsp? ...

  3. java校招一些面试的题目

    数组和链表的区别 数组静态分配内存,链表动态分配内存: 数组在内存中连续,链表不一定连续: 数组元素在栈区,链表元素在堆区: 数组利用下标定位,时间复杂度为O(1),链表定位元素时间复杂度O(n) 数 ...

  4. 吴裕雄--天生自然JAVAIO操作学习笔记:字符编码与对象序列化

    public class CharSetDemo01{ public static void main(String args[]){ System.out.println("系统默认编码: ...

  5. 管理和安装 chart【转】

    安装 chart 当我们觉得准备就绪,就可以安装 chart,Helm 支持四种安装方法: 安装仓库中的 chart,例如:helm install stable/nginx 通过 tar 包安装,例 ...

  6. ubuntu 新建用户后 不能使用TAB键、上下键,命令行不显示当前路径的解决

    因默认ubuntu创建的普通帐号,默认shell为/bin/sh,而这不支持tab等键的,所以将「指定用户」帐号的shell改为/bin/bash就可以了. 1.查看当前的shell:# echo $ ...

  7. pandas包 —— drop()、sort_values()、drop_duplicates()

    一.drop() 函数 当你要删除某一行或者某一列时,用drop函数,它不改变原有的df中的数据,而是返回另一个dataframe来存放删除后的数据. 1.命令: df.drop() 删除行:df.d ...

  8. python基础数据类型--列表(list)

    python基础数据类型--列表(list) 列表是我们在后面经常用到的数据类型之一,通过列表可以对数据类型进行增.删.改.查等操作 一列表的增.删.改.查 1增: 1.1增加到最后   append ...

  9. Gym - 101158C Distribution Center

    题意:n个传送带,传送带i运送编号为i的物品,机器人可以负责把传送带i上的物品放到传送带i + 1上,也可以把传送带i + 1上的物品放到传送带i上,机器人分布在传送带上x轴的不同位置,问每个传送带最 ...

  10. sqlite if not exists应用实例

    INSERT or replace INTO [main].[RecordInfo]([WorkID],[bArtificialAttendance],[fThreshold],[Attendance ...