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

dp-基础版动态规划(动态规划每日一题计划)10/50

 

最小路径和

class Solution {public static int minPathSum(int[][] grid) {int dp[][]=new int[grid.length][grid[0].length];dp[0][0]=grid[0][0];for(int i=1;i<grid[0].length;i++){dp[0][i]=grid[0][i]+dp[0][i-1];}for(int i=1;i<grid.length;i++){dp[i][0]=grid[i][0]+dp[i-1][0];}for(int i=1;i< grid.length;i++){for(int j=1;j<grid[i].length;j++){dp[i][j]=Math.min(dp[i-1][j],dp[i][j-1])+grid[i][j];}}return dp[grid.length-1][grid[0].length-1];}
}

初始化第一行和第一列,除了第一行第一列,其他的每个位置继承上/左的距离,选择最短的那个即可。 

不同路径Ⅱ

import java.util.Arrays;
class Solution {public static int uniquePathsWithObstacles(int[][] obstacleGrid) {int dp[][] = new int[obstacleGrid.length][obstacleGrid[0].length];for (int i = 0; i < obstacleGrid.length; i++) {for (int j = 0; j < obstacleGrid[0].length; j++) {if (i == 0 && j == 0 && obstacleGrid[i][j] != 1) {dp[i][j] = 1;continue;}if (obstacleGrid[i][j] == 1) {dp[i][j] = 0;} else {try {dp[i][j] += dp[i - 1][j] + dp[i][j - 1];} catch (Exception e) {try {dp[i][j] += dp[i][j - 1];} catch (Exception k) {dp[i][j] += dp[i - 1][j];}}}}}return dp[obstacleGrid.length - 1][obstacleGrid[0].length - 1];}
}

判断,嵌套...

三角形最小路径和

数塔问题

class Solution {public static int minimumTotal(List<List<Integer>> triangle) {int f[][] = new int[triangle.size()][triangle.get(triangle.size() - 1).size()];// 初始值 f[i][j] 4 1 8 3for (int i = 0; i < triangle.get(triangle.size() - 1).size(); i++) {f[triangle.size() - 1][i] = triangle.get(triangle.size() - 1).get(i);}for (int i = triangle.size() - 1; i >= 0; i--) {for (int j = 0; j < triangle.get(i).size(); j++) {try {f[i][j] += Math.min(f[i + 1][j], f[i + 1][j + 1]) + triangle.get(i).get(j);} catch (Exception e) {f[i][j] = triangle.get(i).get(j);}}}return f[0][0];}
}

下降路径最小和​​​​​​​ 

class Solution {public static void main(String[] args) {System.out.println(minFallingPathSum(new int[][]{{2, 1, 3}, {6, 5, 4}, {7, 8, 9}}));}public static int minFallingPathSum(int[][] matrix) {int f[][] = new int[matrix.length][matrix[0].length + 2];for (int i = 0; i < matrix.length; i++) {for (int j = 0; j < matrix[0].length + 2; j++) {f[i][j] = Integer.MAX_VALUE;}}for (int i = 1; i <= matrix[0].length; i++) {f[matrix.length - 1][i] = matrix[matrix.length - 1][i - 1];}for (int i = matrix.length - 2; i >= 0; i--) {for (int j = 1; j <= matrix[0].length; j++) {f[i][j] = Math.min(f[i + 1][j], Math.min(f[i + 1][j + 1], f[i + 1][j - 1])) + matrix[i][j - 1];}}int minv = Integer.MAX_VALUE;for (int i = 1; i <= matrix[0].length; i++) {minv = Math.min(minv, f[0][i]);}return minv;}
}

 

 

http://www.lryc.cn/news/252938.html

相关文章:

  • 轻食沙拉店外卖配送小程序商城效果如何
  • Oracle ADRCI工具使用说明
  • Amazon CodeWhisperer 正式可用, 并面向个人开发者免费开放
  • 8-Hive原理与技术
  • cloudflare Tunnel完整
  • 微信聊天窗口测试用例
  • Linux下配置邮箱客户端MUTT,整合msmtp + procmail + fetchmail
  • [每周一更]-(第75期):Go相关粗浅的防破解方案
  • 停留时间是您需要跟踪的 SEO 指标
  • ES常用操作语句
  • MicroPython STM32F4 RTC功能使用介绍
  • 【鸿蒙应用ArkTS开发系列】- 选择图片、文件和拍照功能实现
  • 公有云迁移研究——AWS Route53
  • 浪潮信息KeyarchOS——保卫数字未来的安全防御利器
  • python-单词本|通讯录
  • oracle impdp 导入元数据表空间异常增大的解决办法
  • 网站高可用架构设计基础
  • 基础堆溢出原理与DWORD SHOOT实现
  • ts的一些
  • LORA概述: 大语言模型的低阶适应
  • 关于在PyTorch中使用cudnn.benchmark= True
  • re:Invent大会,亚马逊云科技为用户提供端到端的AI服务
  • 23、什么是卷积的 Feature Map?
  • 安装获取mongodb
  • 【模电】基本共射放大电路的工作原理及波形分析
  • Oracle:左连接、右连接、全外连接、(+)号详解
  • virtualbox上win7企业微信CPU高问题
  • 【华为OD题库-055】金字塔/微商-java
  • OpenVINO异步Stable Diffusion推理优化方案
  • 51单片机的智能加湿器控制系统【含proteus仿真+程序+报告+原理图】