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

【中等】矩阵的最小路径和-Java:经典动态规划方法

分享一个大牛的人工智能教程。零基础!通俗易懂!风趣幽默!希望你也加入到人工智能的队伍中来!请轻击人工智能教程大家好!欢迎来到我的网站! 人工智能被认为是一种拯救世界、终结世界的技术。毋庸置疑,人工智能时代就要来临了,科… 继续阅读 前言https://www.captainai.net/troubleshooter

package live.every.day.ProgrammingDesign.CodingInterviewGuide.RecursionAndDynamicPrograming; /** * 矩阵的最小路径和 * * 【题目】 * 给定一个矩阵m,从左上角开始每次只能向右或者向下走,最后到达右下角的位置,路径上所有的数字累加起来就是路径和,返回所有 * 的路径中最小的路径和。 * * 【难度】 * 中等 * * 【解答】 * 经典动态规划方法。假设矩阵m的大小为MxN,行数为M,列数为N。先生成大小和m一样的矩阵dp,dp[i][j]的值表示从左上角 * 即(0,0)位置走到(i,j)位置的最小路径和。对m的第一行的所有位置来说,即(0,j)(0<=j<N),从(0,0)位置走到(0,j)位置只能 * 向右走,所以(0,0)位置到(0,j)位置的路径和就是m[0][0..j]这些值的累加结果。同理,对m的第一列的所有位置来说,即(i,0) * (0<=i<M),从(0,0)位置走到(i,0)位置只能向下走,所以(0,0)位置到(i,0)位置的路径和就是m[0..i][0]这些值的累加结果。 * 除第一行和第一列的其他位置(i,j)外,都有左边位置(i-1,j)和上边位置(i,j-1)。从(0,0)到(i,j)的路径必然经过位置(i-1,j) * 或位置(i,j-1),所以,dp[i][j]=min{dp[i-1][j],dp[i][j-1]}+m[i][j],含义是比较从(0,0)位置开始,经过(i-1,j) * 位置最终到达(i,j)的最小路径和经过(i,j-1)位置最终到达(i,j)的最小路径之间,哪条路径的路径和更小。那么更小的路径和就是 * dp[i][j]的值。 * 除第一行和第一列之外,每一个位置都考虑从左边到达自己的路径和更小还是从上边达到自己的路径更小。最右下角的值就是整个问题 * 的答案。具体过程请参看如下代码中的minPathSum1方法。 * 矩阵中一共有MxN个位置,每个位置都计算一次从(0,0)位置到达自己的最小路径和,计算的时候只是比较上边位置的最小路径和与左 * 边位置的最小路径和哪个更小,所以时间复杂度为O(MxN),dp矩阵的大小为MxN,所以额外空间复杂度为O(MxN)。 * * @author Created by LiveEveryDay */ public class MatrixMinPathSum1 { public static int minPathSum1(int[][] m) { if (m == null || m.length == 0 || m[0] == null || m[0].length == 0) { return 0; } int row = m.length; int col = m[0].length; int[][] dp = new int[row][col]; dp[0][0] = m[0][0]; for (int i = 1; i < row; i++) { dp[i][0] = dp[i - 1][0] + m[i][0]; } for (int j = 1; j < col; j++) { dp[0][j] = dp[0][j - 1] + m[0][j]; } for (int i = 1; i < row; i++) { for (int j = 1; j < col; j++) { dp[i][j] = Math.min(dp[i - 1][j], dp[i][j - 1]) + m[i][j]; } } return dp[row - 1][col - 1]; } public static void main(String[] args) { int[][] m = {{1, 3, 5, 9}, {8, 1, 3, 4}, {5, 0, 6, 1}, {8, 8, 4, 0}}; System.out.printf("The min path sum is: %d", minPathSum1(m)); } } // ------ Output ------ /* The min path sum is: 12 */
http://www.jsqmd.com/news/707252/

相关文章:

  • 集成学习中强弱学习者的原理与实践指南
  • 如何快速掌握AR/VR技术开发:面向初学者的完整指南
  • 基于RAG与向量数据库的Claude长上下文管理工具实战指南
  • VQE算法在量子化学计算中的应用与优化
  • 深入解析google/adk-java:基于ADB协议实现Android设备高效通信
  • GoPro WiFi Hack实战项目:构建智能相机控制系统的完整案例
  • llvmlite与Numba的完美结合:打造高性能Python应用的终极方案
  • 6种核心降维算法原理与Python实战指南
  • AWS SageMaker模型监控终极指南:从入门到精通
  • 如何在10分钟内搭建PHPCI:PHP项目持续集成从零到一
  • MCP 2026集成必须签的3份协议、配置的4类密钥、验证的5层签名——2024Q3最新合规快照
  • DevDocs安全防护机制:防止XSS和内容污染的完整指南
  • CSS如何实现移动端视口适配_利用rem与vw单位构建响应式布局
  • Cursor AI代码规范:用规则集提升AI生成代码质量与团队协作效率
  • Particalground完全配置手册:20个参数详解与实战案例
  • Material Design Lite按钮组件完全指南:5种样式实战
  • PyTorch实现多元线性回归:原理与实战指南
  • Phi-4-mini-flash-reasoning多场景:技术面试题自动评分与思路评估体系
  • React高阶组件类型定义终极指南:10个实战技巧助你快速掌握HOC模式
  • 终极Docker配置管理指南:环境变量与密钥安全管理最佳实践
  • 农村博士的消费困境:攒多少钱才敢买杯奶茶?
  • 如何用ChatGLM-6B打造你的专属金融分析AI助手:把握市场趋势与投资机会的完整指南
  • MCP插件兼容性崩塌预警,2026 Q1已致47%企业开发流中断,如何紧急迁移并重构?
  • Banana Vision Studio的Java面试题解析:工业AI开发核心知识点
  • terminal-in-react项目贡献指南:从代码提交到插件开发的完整流程
  • Spring Security RBAC:基于角色的动态权限认证系统终极指南
  • Mermaid Live Editor 完整攻略:用文本轻松绘制专业图表
  • 如何用GORM实现自动化数据处理:从定时任务到高效数据管理的完整指南
  • 工业级网络视频录像机(NVR)日志分析:千问3.5-9B智能运维案例
  • R语言决策树分类实战:从原理到调参