当前位置: 首页 > news >正文

1631. 最小体力消耗路径

文章目录

  • 题意
  • 思路
  • 代码

题意

题目链接

思路

搜索

代码

class Solution {
public:
    int minimumEffortPath(vector<vector<int>>& heights) {
        int m = heights.size();
        int n = heights[0].size();
        int x_add[] = {0, 0, 1, -1};
        int y_add[] = {1, -1, 0, 0};
        if (m == 1 && n == 1)
            return 0;
        vector<vector<int>> dp;
        for (int i = 0; i < m; i++)
            dp.push_back(vector<int>(n, 0x3fffffff));
        priority_queue<pair<int, pair<int, int>>> Q;
        dp[0][0] = 0;
        Q.push(make_pair(0, make_pair(0, 0)));
        while (!Q.empty()) 
        {
            const int num = -Q.top().first;
            const int x = Q.top().second.first;
            const int y = Q.top().second.second;
          //  cout << num << " " << x <<" " << y <<endl;
            Q.pop();
            for (int i = 0; i < 4; i++) 
            {
                const int x_tmp = x + x_add[i];
                const int y_tmp = y + y_add[i];
                if (x_tmp < 0 || x_tmp >= m || y_tmp < 0 || y_tmp >= n)
                    continue;
                const int num_tmp = max(num, abs(heights[x][y] - heights[x_tmp][y_tmp]));
                if (num_tmp < dp[x_tmp][y_tmp])
                {
                    // if (x_tmp == m - 1 && y_tmp == n - 1)
                    //     return num_tmp;
                    dp[x_tmp][y_tmp] = num_tmp;
                    Q.push(make_pair(-num_tmp, make_pair(x_tmp, y_tmp)));
                }
            }
        }
        return dp[m - 1][n - 1];
    }
};

相关文章:

  • Quartz 数据持久化 接入MySQL数据库 数据不丢失 数据入库
  • 人工智能通识速览(Part4. 评估指标)
  • Android WiFi协议之P2P介绍与实践
  • git功能点管理
  • Redis 与 MongoDB 对比分析
  • Stable Diffusion XL、SD3 与 Flux 模型常用优化器总结
  • 【群晖】挂载小雅alist到AList网盘中
  • Android Automotive车载系统面试题及参考答案
  • Swift语言的云存储
  • 11231231
  • 轨检探伤专用一体机平板电脑:为铁路安全保驾护航
  • docker的几种网络模式
  • 从搜索丝滑过渡到动态规划的学习指南
  • 数据库50个练习
  • 各开源协议一览
  • js前端对时间进行格式处理
  • 数据结构与算法-数学-基础数学算法(筛质数,最大公约数,最小公倍数,质因数算法,快速幂,乘法逆元,欧拉函数)
  • pyTorch-迁移学习-图片数据增强-四种天气图片的多分类问题
  • 群体智能优化算法-白鲨优化算法(White Shark Optimizer,WSO,含Matlab源代码)
  • JS中的WeakMap
  • 这个东西每道菜里都有,却可能让你得一身病,做好这些能避免
  • 研究显示:肺活量衰减始于20至25岁
  • 俄乌直接谈判勉强收场,特朗普再次“电话外交”能否有用?|907编辑部
  • 黄仁勋:新一代计算平台GB300三季度上市,AI计算能力每十年提升100万倍
  • 墨海军训练舰在纽约撞桥,墨总统:对遇难者表示悲痛,将跟进调查
  • 以军证实空袭也门多个港口