【走迷宫】

题目

DFS代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N = 110;
int matrix[N][N];
int n, m;
int dx[4] = {-1, 0, 1, 0}, dy[4] = {0, 1, 0, -1};
int dis[N][N];
void dfs(int x, int y, int cnt)
{
    if(cnt > dis[n-1][m-1]) return;
    if(x == n-1 && y == m-1) return;


    for(int i = 0; i < 4; i++)
    {
        int nx = x + dx[i], ny = y + dy[i];
        
        if(nx < 0 || ny < 0 || nx >= n || ny >= m || matrix[nx][ny]) continue;
        
        if(dis[nx][ny] > dis[x][y] + 1)
        {
            dis[nx][ny] = dis[x][y] + 1;
            dfs(nx, ny, cnt+1);
        }
    }
}
int main()
{
    scanf("%d%d", &n, &m);
    for(int i = 0; i < n; i++)
    {
        
        for(int j = 0; j < m; j++)
        {
            scanf("%d", &matrix[i][j]);
        }
    }
    memset(dis, 0x3f, sizeof dis);        
    dis[0][0] = 0;
    dfs(0, 0, 0);
    cout << dis[n-1][m-1];
    
    return 0;
}

优化:

1.if(cnt >= res) return; (较好)

2.if(dis[x][y] < cnt) return; (较好)
else dis[x][y] = cnt;

3. if(dis[nx][ny] > dis[x][y] + 1) (非常好)
{
dis[nx][ny] = dis[x][y] + 1;
dfs(nx, ny, cnt+1);
}

优化1+优化2都不如单用优化3

优化3可以替代优化2,同时可以不需要visited访问数组、cnt参数、res。

优化1可以和优化3搭配(需要cnt参数),效果最好,比单用优化3快一倍。为什么?

注意:优化2中和优化3中均不能加等号,前者会导致错误,后者会TLE。为什么?

BFS代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
typedef pair<int, int> PII;
#define f first
#define s second

const int N = 110;
int g[N][N];
int n, m;
int dx[4] = {-1, 0, 1, 0}, dy[4] = {0, 1, 0, -1};
int dis[N][N];
int bfs(int a, int b)
{
    queue<PII> q;
    q.push({a,b});
    dis[a][b] = 0;
    while(q.size())
    {
        PII u = q.front();
        q.pop();
        for(int i = 0; i < 4; i++)
        {
            int nx = u.f + dx[i], ny = u.s + dy[i];
            if(nx >= 0 && ny >= 0 && nx < n && ny < m && !g[nx][ny] && dis[nx][ny] == -1)
            {
                q.push({nx, ny});
                dis[nx][ny] = dis[u.f][u.s] + 1;
            }

        }
    }
    
    return dis[n-1][m-1];
}
int main()
{
    scanf("%d%d", &n, &m);
    for(int i = 0; i < n; i++)
    {
        
        for(int j = 0; j < m; j++)
        {
            scanf("%d", &g[i][j]);
        }
    }
    memset(dis, -1, sizeof dis);
    cout << bfs(0, 0);
    
    return 0;
}

数组实现

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
typedef pair<int, int> PII;
#define f first
#define s second

const int N = 110;
int g[N][N];
PII q[N * N];
int n, m;
int dx[4] = {-1, 0, 1, 0}, dy[4] = {0, 1, 0, -1};
int dis[N][N];
int bfs(int a, int b)
{
    int h = 0, t = 0;
    q[0] = {a, b};
    dis[a][b] = 0;
    while(h <= t)
    {
        auto u = q[h++];
        for(int i = 0; i < 4; i++)
        {
            int nx = u.f + dx[i], ny = u.s + dy[i];
            if(nx >= 0 && ny >= 0 && nx < n && ny < m && !g[nx][ny] && dis[nx][ny] == -1)
            {
                q[++t] = {nx, ny};
                dis[nx][ny] = dis[u.f][u.s] + 1;
            }
        }
    }
    return dis[n-1][m-1];
}
int main()
{
    scanf("%d%d", &n, &m);
    for(int i = 0; i < n; i++)
    {
        
        for(int j = 0; j < m; j++)
        {
            scanf("%d", &g[i][j]);
        }
    }
    memset(dis, -1, sizeof dis);
    cout << bfs(0, 0);
    
    return 0;
}
相关推荐
冲帕Chompa1 小时前
图论part10 bellman_ford算法
数据结构·算法·图论
緈福的街口1 小时前
【leetcode】144. 二叉树的前序遍历
算法·leetcode
GG不是gg1 小时前
排序算法之基础排序:冒泡,选择,插入排序详解
数据结构·算法·青少年编程·排序算法
随意起个昵称2 小时前
【双指针】供暖器
算法
倒霉蛋小马2 小时前
最小二乘法拟合直线,用线性回归法、梯度下降法实现
算法·最小二乘法·直线
codists2 小时前
《算法导论(第4版)》阅读笔记:p82-p82
算法
埃菲尔铁塔_CV算法2 小时前
深度学习驱动下的目标检测技术:原理、算法与应用创新
深度学习·算法·目标检测
float_com3 小时前
【背包dp-----分组背包】------(标准的分组背包【可以不装满的 最大价值】)
算法·动态规划
丶Darling.3 小时前
Day119 | 灵神 | 二叉树 | 二叉树的最近共公共祖先
数据结构·c++·算法·二叉树
医只鸡腿子4 小时前
3.2/Q2,Charls最新文章解读
数据库·数据挖掘·数据分析·深度优先·数据库开发