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

动态规划技巧点

动规五部曲(来自b站卡哥):1、确定DP数组中i、j…的含义。2、确定DP推导式。3、DP数组初始化。4、DP数组遍历顺序。5、DP数组打印校验。

  • 父问题、子问题有些许区别:LeetCode343.整数拆分
    今天在哔哩哔哩上刷到了一个非常有意思的leetcode整数拆分的题,博主利用动态规划。我暂时没有想到动态规划来求解,因此先尝试一下记忆性递归,没想到击败100%用户,暂时不清楚leetcode屏蔽逻辑。该题并不是很难,但有一个递归技巧点,因此进行记录。
class Solution {public int integerBreak(int n) {return integerBreakBy(n, new int[n], true);}public int integerBreakBy(int i, int[] data, boolean flag){if(i <= 1){return 1;}int max = -1;int a = flag ? i - 1 : i;for(int j = 1; j <= a; j++){int i_j = 0;if(data[i - j] == 0)data[i - j] = integerBreakBy(i - j, data, false);int cur_data = j * data[i - j];max = max < cur_data ? cur_data : max;  }return max;}
}

由于该题解要求拆出的数字个数要大于1,但是在子递归中,不用进行拆分就也是可以的,因此,引入了一个flag参数,当第一次进行拆分的时候,只要拆分出两个,子问题没有这条限制,所以引入了一个flag。

  • dp数组中记录的不一定是整体最优,可能是是包含当前值的最优值,全局最优就可以利用一个变量来记录各个局部最优 300.最长递增子序列
class Solution {public int lengthOfLIS(int[] nums) {int[] dp = new int[nums.length];dp[0] = 1;int max_value = 0;for(int i = 0; i < nums.length; i++){dp[i] = 1;for(int j = 0; j < i; j++){if(nums[i] > nums[j]){dp[i] = Math.max(dp[i], dp[j] + 1);}// dp[i] = Math.max(dp[i], nums[i] > nums[j] ? dp[j] + 1 : 1);}if(dp[i] > max_value)max_value = dp[i];}return max_value;}
}

以上问题中,dp数组并非记录的是全局最优,而是必须包含当前数字的局部最优。全局最优利用max_value来进行记录。一维dp中,很多需要子遍历的(即第二层遍历j)。

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

相关文章:

  • 深度学习之pytorch常见的学习率绘制
  • Spring Boot集成SQL Server快速入门Demo
  • 低代码牵手 AI 接口:开启智能化开发新征程
  • 【已解决】git push一直提示输入用户名及密码、fatal: Could not read from remote repository的问题
  • python语言基础-4 常用模块-4.13 其他模块
  • 微信小程序=》基础=》常见问题=》性能总结
  • JWT深度解析:Java Web中的安全传输与身份验证
  • 使用Java爬虫获取商品订单详情:从API到数据存储
  • Mybatis中批量插入foreach优化
  • Word VBA如何间隔选中多个(非连续)段落
  • Linux系统常用操作与命令指南
  • StructuredStreaming (一)
  • 由播客转向个人定制的音频频道(1)平台搭建
  • [自然语言处理] [AI]深入理解语言与情感分类:从基础到深度学习的进展
  • 【GPTs】Gif-PT:DALL·E制作创意动图与精灵动画
  • 云原生周刊:Istio 1.24.0 正式发布
  • Linux设置jar包开机启动
  • 计算机视觉和机器人技术中的下一个标记预测与视频扩散相结合
  • C语言之简单的获取命令行参数和环境变量
  • STL之vecor的使用(超详解)
  • SystemVerilog学习笔记(一):数据类型
  • Linux软件包管理与Vim编辑器使用指南
  • 每日一练 | 包过滤防火墙的工作原理
  • AR眼镜方案_AR智能眼镜阵列/衍射光波导显示方案
  • SpringBoot(十九)创建多模块Springboot项目(完整版)
  • Navicat 17 功能简介 | 单元格编辑器
  • MySQL【四】
  • 简单叙述 Spring Boot 启动过程
  • 微信小程序自定义tabbar;禁用某个tab;修改某个tab的样式
  • 力扣113:路径总和II