码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 『LeetCode|每日一题』---->最小路径和


    目录

    1.每日一句

    2.作者简介

    『LeetCode|每日一题』最小路径和

    1.每日一题

    2.解题思路

            2.1 思路分析

            2.2 核心代码

            2.3 完整代码

            2.4 运行结果


    1.每日一句

    希望冬天的风能吹散一年里所有的遗憾

    2.作者简介

    🏡个人主页:XiaoXiaoChen-2716 

    📚学习专栏:力扣专栏

    🕒发布日期:2022/11/27

    『LeetCode|每日一题』最小路径和

    1.每日一题

    原文链接--->点我

    2.解题思路

            2.1 思路分析

    典型的动态规划题,相信很多小伙伴可以用一个dp数组轻松解决,但是也可以在原数组上改动,这样空间复杂度就只有O(1)了

            S1:首先是特殊情况判断,矩阵为空的情况就直接返回0即可;

            S2:因为终点已经规定了,方向也已经规定了,所以第一列和第一行的所有位置的值都是确定的,我们用两个for循环就可以初始化了;

            S3:接下来就是动态规划的方程式,我们每次选取当前位置的左边或者上面值小的那个就可以了,用一个双层for循环即可实现,当前位置i , j,那么它的上面就是i - 1 , j,它的左边位置就是i , j - 1,选最小的那个即可;

            S4:最后返回矩阵右下角的位置的值即可

            2.2 核心代码

    1. for(int i = 1 ; i < col ; i++){
    2. for(int j = 1 ; j < row ; j++){
    3. grid[i][j] = Math.min(grid[i - 1][j] , grid[i][j - 1]) + grid[i][j];
    4. }
    5. }

            2.3 完整代码

    1. class Solution {
    2. public int minPathSum(int[][] grid) {
    3. int col = grid.length; //行
    4. int row = grid[0].length; //列
    5. if(col == 0 && row == 0) return 0;
    6. for(int i = 1 ; i < col ; i++){
    7. grid[i][0] += grid[i - 1][0];
    8. }
    9. for(int i = 1 ; i < row ; i++){
    10. grid[0][i] += grid[0][i - 1];
    11. }
    12. for(int i = 1 ; i < col ; i++){
    13. for(int j = 1 ; j < row ; j++){
    14. grid[i][j] = Math.min(grid[i - 1][j] , grid[i][j - 1]) + grid[i][j];
    15. }
    16. }
    17. return grid[col - 1][row - 1];
    18. }
    19. }

             2.4 运行结果


    🍁 类似题目推荐:

    1.数据结构基础

    2.算法专项练习

    3.剑指offer专项练习

    4.推荐一个学习网站:LeetCode,算法的提升在于日积月累,只有每天练习才能保持良好的状态

    如果文章对各位大佬有帮助就支持一下噢,不好的地方请各位大佬多多指教! 

  • 相关阅读:
    论文阅读——ELECTRA
    写一个宏,计算结构体中某变量相对于首地址的偏移,并给出说明
    Golang 方法使用的注意事项和细节
    【C++11算法】find_if_not、 copy_if、copy_n
    Qt之Model/View架构
    算法体系-12 第 十二 二叉树的基本算法
    【Linux】 reboot 命令使用
    痞子衡嵌入式:恩智浦i.MX RT1xxx系列MCU启动那些事(12)- 从SD/eMMC启动
    Turtlebot3-burger入门教程#foxy版#-PC安装
    【ES实战】ES创建Transports客户端时间过长分析
  • 原文地址:https://blog.csdn.net/weixin_51065489/article/details/128069208
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号