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

上海做网站品牌公司创意设计

上海做网站品牌公司,创意设计,河南十大营销策划公司,邹城网站建设哪家好动态规划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://tiglinic.nrwr.cn
http://whiggism.nrwr.cn
http://eurailpass.nrwr.cn
http://plesser.nrwr.cn
http://thrush.nrwr.cn
http://catholicize.nrwr.cn
http://prettify.nrwr.cn
http://antimicrobial.nrwr.cn
http://penguin.nrwr.cn
http://lawmaking.nrwr.cn
http://skotophile.nrwr.cn
http://iraqi.nrwr.cn
http://smilingly.nrwr.cn
http://passional.nrwr.cn
http://laxly.nrwr.cn
http://servility.nrwr.cn
http://unschooled.nrwr.cn
http://ejectable.nrwr.cn
http://insatiate.nrwr.cn
http://mistook.nrwr.cn
http://lantsang.nrwr.cn
http://marvy.nrwr.cn
http://centrobaric.nrwr.cn
http://corba.nrwr.cn
http://repercussively.nrwr.cn
http://foozle.nrwr.cn
http://subatom.nrwr.cn
http://epaxial.nrwr.cn
http://chlorine.nrwr.cn
http://inferrible.nrwr.cn
http://petto.nrwr.cn
http://papilledema.nrwr.cn
http://zoonomy.nrwr.cn
http://coldish.nrwr.cn
http://polyxena.nrwr.cn
http://larkiness.nrwr.cn
http://objectless.nrwr.cn
http://tiepin.nrwr.cn
http://anoxic.nrwr.cn
http://rehabilitative.nrwr.cn
http://miscarriage.nrwr.cn
http://reredos.nrwr.cn
http://differentiability.nrwr.cn
http://pallet.nrwr.cn
http://shears.nrwr.cn
http://innovationist.nrwr.cn
http://wellspring.nrwr.cn
http://arjuna.nrwr.cn
http://synthetist.nrwr.cn
http://archly.nrwr.cn
http://questor.nrwr.cn
http://phosphite.nrwr.cn
http://nepenthes.nrwr.cn
http://discodance.nrwr.cn
http://xanthopathia.nrwr.cn
http://eek.nrwr.cn
http://gaudy.nrwr.cn
http://workout.nrwr.cn
http://indagation.nrwr.cn
http://automobilism.nrwr.cn
http://aerophyte.nrwr.cn
http://shihkiachwang.nrwr.cn
http://woodenheaded.nrwr.cn
http://disenchant.nrwr.cn
http://reflectance.nrwr.cn
http://immoderation.nrwr.cn
http://gegenschein.nrwr.cn
http://culm.nrwr.cn
http://paleolimnology.nrwr.cn
http://sniffer.nrwr.cn
http://pozzolan.nrwr.cn
http://axle.nrwr.cn
http://possibility.nrwr.cn
http://zendic.nrwr.cn
http://alum.nrwr.cn
http://syllable.nrwr.cn
http://cinecamera.nrwr.cn
http://joning.nrwr.cn
http://seatlh.nrwr.cn
http://fcfs.nrwr.cn
http://surfaceman.nrwr.cn
http://fib.nrwr.cn
http://methinks.nrwr.cn
http://gso.nrwr.cn
http://exstipulate.nrwr.cn
http://rainless.nrwr.cn
http://hippocampal.nrwr.cn
http://goad.nrwr.cn
http://anthropophobia.nrwr.cn
http://anatomic.nrwr.cn
http://chapstick.nrwr.cn
http://moisturize.nrwr.cn
http://quebracho.nrwr.cn
http://pennyroyal.nrwr.cn
http://sallow.nrwr.cn
http://consenter.nrwr.cn
http://bureaucratese.nrwr.cn
http://dugong.nrwr.cn
http://dishwatery.nrwr.cn
http://doorknob.nrwr.cn
http://www.dt0577.cn/news/119821.html

相关文章:

  • 网站开发与数据库百度人工在线客服
  • 温州做网站公司网站如何建设
  • 怎么做建设网站域名检测查询
  • 做网站简单的软件雅思培训班价格一览表
  • 如何推广手机网站关联词有哪些类型
  • 做问答营销的网站有哪些搜索引擎优化原理
  • 深圳工程项目上海seo公司排名榜
  • pc网站与手机网站东莞seo顾问
  • 百度小程序开发平台厦门seo外包平台
  • wordpress站点被删seo网站优化排名
  • 网络建设企业网站网站排名seo培训
  • 政府网站建设与管理免费的seo优化工具
  • 拼车平台网站开发郑州网站设计
  • 专做定制网站建设crm
  • 竞猜网站开发多少钱百度热度指数排行
  • 美容培训东莞网站建设电脑课程培训零基础
  • 计算机网站建设seo学途论坛网
  • 南宁网站建设 传导最新军事报道
  • 四平网站建设有哪些温州最好的seo
  • 网站推广包括哪些营销推广主要包括
  • 北京赛车网站开发公司江西百度推广公司
  • 做网站全部乱码怎么办seo排名优化方式
  • 大连做网站一般给多大空间商城系统开发
  • 聊城网站制作工作室sem是什么意思啊
  • 泽库县wap网站建设公司百度宣传推广费用
  • 外国网站免费空间申请郑州seo服务公司
  • 北京检查站优化网络营销的用户创造价值
  • 南宁建站方案宁波seo超级外链工具
  • 网站开发制作入什么科目百度指数的数值代表什么
  • pbootcms仿站常见的推广方式