LeeCode 1631 Dijkstra

题意

传送门 LeeCode 1631. 最小体力消耗路径

题解

路径权值为 m a x { ∣ h i − h j ∣ } , e ( i , j ) ∈ E max\{|h_i-h_j|\},e(i,j)\in E max{hihj},e(i,j)E,是非严格递增的,那么可以使用 D i j k s t r a Dijkstra Dijkstra 求解单源最短路。

struct edge
{
    int to, cost;
};
class Solution
{
#define maxn 10005
    typedef pair<int, int> P;

public:
    vector<edge> G[maxn];
    int dx[4] = {0, 0, -1, 1}, dy[4] = {1, -1, 0, 0};
    int dis[maxn];
    bool used[maxn];
    void add_edge(int u, int v, int cost)
    {
        G[u].push_back(edge{v, cost});
        G[v].push_back(edge{u, cost});
    }
    int dijkstra(int s, int t)
    {
        memset(dis, 0x3f, sizeof(dis));
        dis[s] = 0;
        priority_queue<P, vector<P>, greater<P>> q;
        q.push(P(0, s));
        while (!q.empty())
        {
            P p = q.top();
            q.pop();
            int v = p.second, d = p.first;
            if (used[v])
                continue;
            used[v] = 1;
            for (int i = 0; i < G[v].size(); ++i)
            {
                edge &e = G[v][i];
                int d2 = max(d, e.cost);
                if (d2 < dis[e.to])
                {
                    dis[e.to] = d2;
                    q.push(P(d2, e.to));
                }
            }
        }
        return dis[t];
    }
    int minimumEffortPath(vector<vector<int>> &heights)
    {
        int h = heights.size(), w = heights[0].size();
        for (int i = 0; i < h; ++i)
        {
            for (int j = 0; j < w; ++j)
            {
                for (int k = 0; k < 4; ++k)
                {
                    int nx = i + dx[k], ny = j + dy[k];
                    if (nx >= 0 && nx < h && ny >= 0 && ny < w)
                    {
                        add_edge(i * w + j, nx * w + ny, abs(heights[i][j] - heights[nx][ny]));
                    }
                }
            }
        }
        return dijkstra(0, (h - 1) * w + w - 1);
    }
};
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。、可私 6信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 、可私信6博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 、可私信6博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值