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

东莞营销网站建设哪家好空间网络

东莞营销网站建设哪家好,空间网络,WordPress本地可以调出点赞功能吗,建筑公司网站md0095设计风格动态规划part09 198.打家劫舍解题思路 213.打家劫舍II解题思路 337.打家劫舍III解题思路 今天就是打家劫舍的一天,这个系列不算难,大家可以一口气拿下。 198.打家劫舍 题目链接: 198.打家劫舍 视频讲解: 198.打家劫舍 文章讲解&…

动态规划part09

  • 198.打家劫舍
    • 解题思路
  • 213.打家劫舍II
    • 解题思路
  • 337.打家劫舍III
    • 解题思路

今天就是打家劫舍的一天,这个系列不算难,大家可以一口气拿下。

198.打家劫舍

题目链接: 198.打家劫舍
视频讲解: 198.打家劫舍
文章讲解: 198.打家劫舍

解题思路

递归五部曲

  1. 确定dp数组以及下标的含义
    dp[i]:考虑下标i(包括i)以内的房屋,最多可以偷窃的金额为dp[i]。
  2. 确定递推公式
    dp[i] = dp[i - 2] + nums[i] ,即:第i-1房一定是不考虑的,找出 下标i-2(包括i-2)以内的房屋,最多可以偷窃的金额为dp[i-2] 加上第i房间偷到的钱。
  3. dp数组如何初始化
    递推公式的基础就是dp[0] 和 dp[1]
    dp[0] = nums[0],dp[1] = max(nums[0], nums[1]);
  4. 遍历顺序
    从前到后
  5. 举例推导dp数组
// 动态规划
class Solution {public int rob(int[] nums) {if(nums == null || nums.length == 0) return 0;if(nums.length == 1) return nums[0];int[] dp = new int[nums.length];dp[0] = nums[0];dp[1] = Math.max(dp[0], nums[1]);for(int i = 2; i < nums.length; i++){dp[i] = Math.max(dp[i - 1], dp[i - 2] + nums[i]);}return dp[nums.length - 1];}
}

213.打家劫舍II

题目链接: 213.打家劫舍II
视频讲解: 213.打家劫舍II
文章讲解: 213.打家劫舍II

解题思路

对于一个数组,成环的话主要有如下三种情况:
情况一:考虑不包含首尾元素
情况二:考虑包含首元素,不包含尾元素
情况三:考虑包含尾元素,不包含首元素
而情况二 和 情况三 都包含了情况一了,所以只考虑情况二和情况三就可以了。
分析到这里,剩下的和198.打家劫舍就是一样的了。

class Solution {public int rob(int[] nums) {if(nums == null || nums.length == 0) return 0;if(nums.length == 1) return nums[0];return Math.max(robAction(nums, 0, nums.length - 1), robAction(nums, 1, nums.length));}int robAction(int[] nums, int start, int end) {int dp3 = 0;int dp2 = 0;int dp1 = 0;for(int i = start; i < end; i++){dp1 = dp3;dp3 = Math.max(dp1, dp2 + nums[i]);dp2 = dp1;}return dp3;}// 运行没通过 不知道为啥// int robAction(int[] nums, int start, int end) {//     int[] dp = new int[nums.length];//     dp[start] = nums[start];//     dp[start + 1] = Math.max(dp[0], nums[start + 1]);//     for(int i = start + 2; i < end; i++){//         dp[i] = Math.max(dp[i - 1], dp[i - 2] + nums[i]);//     }//     return dp[end - 1];// }
}

337.打家劫舍III

题目链接: 337.打家劫舍III
视频讲解: 337.打家劫舍III
文章讲解: 337.打家劫舍III

解题思路

动态规划和二叉树的结合
动态规划其实就是使用状态转移容器来记录状态的变化,这里可以使用一个长度为2的数组,记录当前节点偷与不偷所得到的的最大金钱。
递归三部曲

  1. 确定递归函数的参数和返回值
    长度为2的dp数组
    dp[0]0记录不偷该节点所得到的的最大金钱,dp[1]1记录偷该节点所得到的的最大金钱。
  2. 确定终止条件
    在遍历的过程中,如果遇到空节点的话,很明显,无论偷还是不偷都是0,所以就返回
  3. 确定遍历顺序
    首先明确的是使用后序遍历。 因为要通过递归函数的返回值来做下一步计算。
    通过递归左节点,得到左节点偷与不偷的金钱。
    通过递归右节点,得到右节点偷与不偷的金钱。
  4. 确定单层递归的逻辑
    如果是偷当前节点,那么左右孩子就不能偷,val1 = cur->val + left[0] + right[0]; (如果对下标含义不理解就再回顾一下dp数组的含义)
    如果不偷当前节点,那么左右孩子就可以偷,至于到底偷不偷一定是选一个最大的,所以:val2 = max(left[0], left[1]) + max(right[0], right[1]);
    最后当前节点的状态就是{val2, val1}; 即:{不偷当前节点得到的最大金钱,偷当前节点得到的最大金钱}
  5. 举例推导dp数组
 // 动态规划
class Solution {public int rob(TreeNode root) {int[] res = robAction(root);return Math.max(res[0], res[1]);}int[] robAction(TreeNode root){int res[] = new int[2]; // res[0] 代表不偷时的价值 res[1]代表偷的时候的价值// 终止递归条件if(root == null){return res;}// 后序遍历// 左右int[] left = robAction(root.left);int[] right = robAction(root.right);// 中res[0] = Math.max(left[0], left[1]) +Math.max(right[0], right[1]);res[1] = root.val + left[0] + right[0];return res;}
}
http://www.yayakq.cn/news/951262/

相关文章:

  • 西安网站seo优化公司一个基于php网站开发课题设计的业务流程描述
  • logo和网站主色调怎么样让网站正常解析
  • 汨罗做网站价格网站该怎么做链接
  • 网络开发软件seochan是什么意思
  • 陕西网站建设排名嘉兴网站建设公司
  • 在线看视频网站怎么做的济南市住房和城乡建设局
  • 网站怎么做动态图片影视cms哪个好
  • 云凡济南网站建设开发电商平台代运营服务
  • html怎么做网站设计营业推广促销
  • 德州建设网站有网站建设与管理试题答案
  • 湖南响应式网站公司商城推广软文范文
  • 太原铁路建设有限公司网站南京做网站最好的公司
  • 哪个跨境电商网站做的最好apico手机app开发
  • 惠州做棋牌网站建设哪家公司便宜wordpress动图打开很慢
  • 做网站的软件公司网络营销策划需要包括哪些内容
  • 三站合一网站建设环球旅行社网站建设规划书论文
  • 电影视频网站建设费用wordpress 电台网站
  • 做网站背景音乐外贸营销推广公司
  • 国外订房网站怎么和做wordpress的菜单和页面跳转
  • 做网站什么语言最好藁城网站建设哪家好
  • jsp网站开发制作桐城网站设计
  • 外文网站开发wordpress轮播的插件下载
  • 德邦物流公司现代物流网站建设与开发重庆市工程建设信息网官网新域名
  • 西宁市建设网站价格低应用软件app
  • 用DW做的网站怎么弄成链接上海seo整站优化
  • 广告网站模板下载不了站点怎么建网页
  • 雅虎网站提交公司做网站是做什么账务处理
  • ftp更换网站搜索网页怎么制作
  • 刚做的网站搜索不到未央区建设局网站
  • 哪个网站可以兼职做效果图海南综合网站两学一做电视夜校