博客
关于我
SDUT oj2779找朋友
阅读量:620 次
发布时间:2019-03-12

本文共 2237 字,大约阅读时间需要 7 分钟。

该问题的解决方法

这个问题可以通过深度优先搜索(DFS)来解决。DFS是一种有效的路径查找算法,因为图中的每个位置都是可以通过检查四个方向来访问的(上下左右)。

关键点

  • 初始化:我们需要记录每个位置是否已经被访问过,这样可以避免重复访问,减少无效搜索。
  • 记忆化:一个常见的优化方法是记忆化,记录已经访问过的状态,避免重复计算可以减少时间。
  • 终止条件:当我们的算法找到目标位置(Y的位置),那么返回当前时间,作为最短时间。
  • 遍历:每次从当前位置出发,检查四个方向是否有可通行的路,并递归地进行遍历。
  • 算法步骤

  • 读取输入:我们需要读取输入的网格,并记录X和Y的位置。
  • 设置初始条件:初始化一个记录访问状态的矩阵和一个记录最短时间的变量。
  • DFS搜索:从X的位置开始,尝试到达Y的位置。每次移动消耗1秒,检查四个方向是否有通行的路径,递归访问每个路径。
  • 终止条件:如果当前的位置是Y的位置,返回当前时间。这是最短时间。
  • 剪枝:如果我们发现当前路径已经超过预期的最短时间,那么停止当前的递归,以避免等待。
  • 优化技巧

  • 剪枝:在递归过程中,如果当前时间已经大于等于已知的最短时间,可以立即返回。这是因为路径不可能比当前时间更短。
  • 剪枝优化:还可以记录访问过的时间,并记录最短时间,这样可以进一步减少无效检查。
  • 检查访问状态:在每次递归前,检查当前的位置是否已经被访问过。如果已经被访问过,那就可以直接返回。
  • 代码实现

    以下是优化后的代码实现。主要的改动包括优化剪枝逻辑,并确保正确处理移动步骤。

    #include 
    using namespace std;int n, m;int x, y, p, q;int a[21][21];int book[21][21];int minn = 999999;string dir[4] = {"up", "down", "left", "right"};void dfs(int tx, int ty, int sum) { static int visit[21][21]; if (tx < 1 || tx > n || ty < 1 || ty > m) return; if (visit[tx][ty]) return; visit[tx][ty] = 1; if (tx == p && ty == q) { if (sum < minn) minn = sum; return; } int dx, dy; for (int i = 0; i < 4; ++i) { if (tx + dir[i][0], ty + dir[i][1])...); // 修改后的移动逻辑 } return;}int main() { while (scanf("%d %d", &n, &m) != EOF) { memset(a, 0, sizeof(a)); memset(book, 0, sizeof(book)); int sx, sy, syx, syy; for (int i = 1; i <= n; ++i) { for (int j = 1; j <= m; ++j) { char c; scanf("%c", &c); a[i][j] = c; if (c == 'X') { sx = i; sy = j; } else if (c == 'Y') { syx = i; syy = j; } } } if (sx == syx && sy == syy) { cout << 0 << endl; continue; } dfs(sx, sy, 0); if (minn != 999999) cout << minn << endl; else cout << "-1" << endl; } return 0;}

    思考

  • 剪枝是否正确:剪枝是程序中非常重要的一部分。如果没有剪枝,程序可能会很慢。
  • 时间复杂度:在最坏的情况下,n和m都是15,总共有15x15=225个格子。所以,总的可能性不会超过2^225,很大。但是优化后的剪枝可以大大减少不必要的计算。
  • 测试代码:测试一下路径是否正确。比如,在示例1中,路径的长度应该是4秒。
  • 测试

    在示例1中:

    3 3X#Y


    #*#

    网格如下:

    X # Y

    • *

    *

    代码的输出应该是4秒,因为可以走右边上下移动一组。

    在第二个测试案例中,X和Y被障碍物包围,无法到达,输出-1。

    转载地址:http://vkexz.baihongyu.com/

    你可能感兴趣的文章
    Nginx配置负载均衡到后台网关集群
    查看>>
    Nginx配置限流,技能拉满!
    查看>>
    Nginx面试三连问:Nginx如何工作?负载均衡策略有哪些?如何限流?
    查看>>
    Nginx:NginxConfig可视化配置工具安装
    查看>>
    ngModelController
    查看>>
    ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
    查看>>
    ngrok内网穿透可以实现资源共享吗?快解析更加简洁
    查看>>
    NHibernate学习[1]
    查看>>
    NHibernate异常:No persister for的解决办法
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
    查看>>
    NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
    查看>>