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

wordpress优先级js兰州网站seo服务

wordpress优先级js,兰州网站seo服务,产品画册设计怎么做,飞速网站排名198.打家劫舍 思路: 1、dp[i]为到第i家偷到的最高金额。 2、如果偷第i家,那么dp[i]dp[i-2]nums[i],如果不偷,则dp[i]dp[i-1],所以递推公式dp[i]max(dp[i-2]nums[i],dp[i-1])。 3、初始值,根据递推公式,我们…

198.打家劫舍

思路:
1、dp[i]为到第i家偷到的最高金额。
2、如果偷第i家,那么dp[i]=dp[i-2]+nums[i],如果不偷,则dp[i]=dp[i-1],所以递推公式dp[i]=max(dp[i-2]+nums[i],dp[i-1])。
3、初始值,根据递推公式,我们需要知道dp[0]和dp[1]。dp[0]=nums[0], dp[1]=max(nums[0],nums[1]);
4、遍历顺序为从小到大遍历nums[i]。

代码如下:

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(nums[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

思路:该题与上一题的区别在于第一个和最后一个房屋相邻。有两种情况:只考虑打劫第1家到倒数第2家;只考虑打劫第2家到最后一家。

代码如下:

class Solution {public int rob(int[] nums) {int len=nums.length;if(nums==null || len==0) return 0;if(len==1) return nums[0];return Math.max(robAction(nums,0,len-1),robAction(nums,1,len));}public int robAction(int[] nums, int start, int end){int x=0,y=0,z=0;for(int i=start;i<end;i++){z=Math.max(x+nums[i],y);x=y;y=z;}return z;}
}

337.打家劫舍III

思路:记录树上每个节点状态的变化,使用一个长度为2的数组,记录当前节点偷与不偷所得到的的最大金钱。

以递归三部曲为框架,融合动规五部曲的进行分析。

1、确定递归函数的参数和返回值
传入参数为当前节点,返回值是一个长度为2的数组。
即dp数组(dp table)以及下标的含义:下标为0记录不偷该节点所得到的的最大金钱,下标为1记录偷该节点所得到的的最大金钱。

2、确定终止条件
空节点无论偷还是不偷都是0,所以返回0。
相当于dp数组的初始化。

3、确定遍历顺序
使用后序遍历, 因为要通过递归函数的返回值来做下一步计算。
通过递归左节点,得到左节点偷与不偷的金钱。
通过递归右节点,得到右节点偷与不偷的金钱。

4、确定单层递归的逻辑
如果是偷当前节点,那么左右孩子就不能偷,val1 = cur->val + left[0] + right[0];
如果不偷当前节点,那么左右孩子就可以偷,至于到底偷不偷一定是选一个最大的,所以:val2 = max(left[0], left[1]) + max(right[0], right[1]);

当前节点的状态就是{val2, val1}; 即:{不偷当前节点得到的最大金钱,偷当前节点得到的最大金钱}

5、举例推导dp数组

代码如下:

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {public int rob(TreeNode root) {int[] res=robAction(root);return Math.max(res[0],res[1]);}public int[] robAction(TreeNode root){int[] res=new int[2];if(root==null) return res;int[] left=robAction(root.left);int[] right=robAction(root.right);res[1]=root.val+left[0]+right[0];res[0]=Math.max(left[0],left[1])+Math.max(right[0],right[1]);return res;}
}
http://www.hengruixuexiao.com/news/50027.html

相关文章:

  • 电商网站设计 页面转化率长沙网站seo方法
  • 网站建设技能考试试题服务营销策划方案
  • 建筑公司网站图片站长统计app软件下载
  • 如何做更改网站的图片磁力bt种子搜索
  • 网站建设电话营销网站怎么打开
  • 如何做好网站网站超级外链
  • 幼儿园微信公众号如何做微网站网络营销和直播电商专业学什么
  • h5响应式网站建设站内推广的方法和工具
  • 可以做分析图的地图网站百度数据开放平台
  • 简洁大气企业网站三只松鼠营销策划书
  • 做网站开通手机验证功能如何做好企业推广
  • wordpress怎么做采集快速整站排名seo教程
  • 怎样做辅导班的网站seo系统源码
  • php网站cms友情链接交换软件
  • 手机h5网站福州短视频seo网站
  • 做眼镜网站草图有什么原则北京网站建设公司哪家好
  • wordpress能做商城天津短视频seo
  • 传媒公司营业执照关于seo如何优化
  • 门户网站要求如何提升关键词的自然排名
  • 网站开发行业怎么样一键识图找原图
  • 做网站应该会什么无人在线观看高清视频单曲直播
  • 查看一个网站的备案人拉新奖励的app排行
  • 做网站推广价格中国数据网
  • 免费ppt模板的软件保定seo网络推广
  • 网站的字体做多大合适网络建站优化科技
  • 怎么提交网站seo公司排名
  • 桂林北站离阳朔多远如何做网络推广
  • 流媒体网站开发自媒体平台注册官网
  • net服装网站建设常德网站设计
  • 基于php的网站开发英文文献同城推广