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

本文共 2293 字,大约阅读时间需要 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 3 X#Y


    #*#

    网格如下:

    X # Y

    • *

    *

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

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

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

    你可能感兴趣的文章
    nodejs框架,原理,组件,核心,跟npm和vue的关系
    查看>>
    Nodejs概览: 思维导图、核心技术、应用场景
    查看>>
    nodejs模块——fs模块
    查看>>
    Nodejs模块、自定义模块、CommonJs的概念和使用
    查看>>
    nodejs生成多层目录和生成文件的通用方法
    查看>>
    nodejs端口被占用原因及解决方案
    查看>>
    Nodejs简介以及Windows上安装Nodejs
    查看>>
    nodejs系列之express
    查看>>
    nodejs系列之Koa2
    查看>>
    Nodejs连接mysql
    查看>>
    nodejs连接mysql
    查看>>
    NodeJs连接Oracle数据库
    查看>>
    nodejs配置express服务器,运行自动打开浏览器
    查看>>
    NodeMCU教程 http请求获取Json中文乱码解决方案
    查看>>
    Nodemon 深入解析与使用
    查看>>
    NodeSession:高效且灵活的Node.js会话管理工具
    查看>>
    node~ http缓存
    查看>>
    node不是内部命令时配置node环境变量
    查看>>
    node中fs模块之文件操作
    查看>>
    Node中同步与异步的方式读取文件
    查看>>