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

那些网站做调查能赚钱建设银行博士后招聘网站

那些网站做调查能赚钱,建设银行博士后招聘网站,免费做淘宝客网站有哪些,在国税网站更换购票员怎么做198.打家劫舍 你是一个专业的小偷#xff0c;计划偷窃沿街的房屋。每间房内都藏有一定的现金#xff0c;影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统#xff0c;如果两间相邻的房屋在同一晚上被小偷闯入#xff0c;系统会自动报警。 给定一个代表每个…198.打家劫舍 你是一个专业的小偷计划偷窃沿街的房屋。每间房内都藏有一定的现金影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统如果两间相邻的房屋在同一晚上被小偷闯入系统会自动报警。 给定一个代表每个房屋存放金额的非负整数数组计算你 不触动警报装置的情况下 一夜之内能够偷窃到的最高金额。 解题思路 确定dp数组含义dp[i]遍历到房屋index为i时所能打劫到的最多钱 确认递推公式dp[i]取决于前一个房屋和前两个房屋是否有被偷如果前一个被偷则不能偷第i个如果第i-2个被偷可选择是否偷第i个。dp[i] max(dp[i-2]nums[i], dp[i-1]) 初始化dp[0] nums[0], dp[1] max(nums[0], nums[1]) 遍历顺序从小到大遍历 打印dp数组 class Solution:def rob(self, nums: List[int]) - int:if len(nums)1:return nums[0]dp [0]*(len(nums))dp[0] nums[0]dp[1] max(nums[0], nums[1])for i in range(2, len(nums)):dp[i] max(dp[i-2]nums[i], dp[i-1])return dp[len(nums)-1] 213.打家劫舍II 你是一个专业的小偷计划偷窃沿街的房屋每间房内都藏有一定的现金。这个地方所有的房屋都 围成一圈 这意味着第一个房屋和最后一个房屋是紧挨着的。同时相邻的房屋装有相互连通的防盗系统如果两间相邻的房屋在同一晚上被小偷闯入系统会自动报警 。 给定一个代表每个房屋存放金额的非负整数数组计算你 在不触动警报装置的情况下 今晚能够偷窃到的最高金额。 解题思路 本题与上一题区别在于环形数组和直线数组环形数组首尾不能同时取值因此分为三种情况 不考虑首尾的数组不考虑尾部的数组不考虑首部的数组 可以发现2 3包含情况一因此只需要在23中取最大值即可。 dp五步骤 确定dp数组含义dp[i]遍历到房屋index为i时所能打劫到的最多钱 确认递推公式dp[i]取决于前一个房屋和前两个房屋是否有被偷如果前一个被偷则不能偷第i个如果第i-2个被偷可选择是否偷第i个。dp[i] max(dp[i-2]nums[i], dp[i-1]) 初始化dp[0] nums[0], dp[1] max(nums[0], nums[1]) 遍历顺序从小到大遍历 打印dp数组 class Solution:def rob(self, nums: List[int]) - int:if len(nums)1:return nums[0]def helper(subnums):if len(subnums)1:return subnums[0]dp [0]*len(subnums)dp[0] subnums[0]dp[1] max(subnums[0], subnums[1])for i in range(2, len(subnums)):dp[i] max(dp[i-2]subnums[i], dp[i-1])print(dp)return dp[len(subnums)-1]return max(helper(nums[:-1]), helper(nums[1:]))  337.打家劫舍III 小偷又发现了一个新的可行窃的地区。这个地区只有一个入口我们称之为 root 。 除了 root 之外每栋房子有且只有一个“父“房子与之相连。一番侦察之后聪明的小偷意识到“这个地方的所有房屋的排列类似于一棵二叉树”。 如果 两个直接相连的房子在同一天晚上被打劫 房屋将自动报警。 给定二叉树的 root 。返回 在不触动警报的情况下 小偷能够盗取的最高金额 。 示例 1: 输入: root [3,2,3,null,3,null,1] 输出: 7 解释: 小偷一晚能够盗取的最高金额 3 3 1 7 解题思路 本体使用递归三部曲结合dp五步骤设置dp[0],dp[1]表示打劫当前节点和不打劫当前节点的最大值每个node有一组对应的dp[0], dp[1]。使用后序遍历当前节点dp值需要结合其左右节点dp进行分析。 递归三步骤确定递归参数确定停止条件递归逻辑。输入参数统一为当前节点即表示为root 当root null停止并返回0再遍历左右子树中间值取最大dp值。 重点理解 val1 root.val leftdp[0] rightdp[0]#行窃root val2 max(leftdp[0],leftdp[1])max(rightdp[0], rightdp[1])#不行窃root选取左右子树行窃或不行窃时的最大值两边取max。 代码如下 # Definition for a binary tree node. # class TreeNode: # def __init__(self, val0, leftNone, rightNone): # self.val val # self.left left # self.right right class Solution:def rob(self, root: Optional[TreeNode]) - int:def helper(root):if not root:return [0,0]leftdp helper(root.left)rightdp helper(root.right)val1 root.val leftdp[0] rightdp[0]#行窃rootval2 max(leftdp[0],leftdp[1])max(rightdp[0], rightdp[1])#不行窃rootreturn [val2, val1]return max(helper(root))
http://www.hkea.cn/news/14428386/

相关文章:

  • 网站管理密码做视频比较好的理财网站
  • 国内有多少家做网站的企业小米网站开发语言
  • 怎么做网站的主页面跨境电商平台网站建设广州
  • 网站建设外包包含内容微信自助下单小程序怎么弄
  • 邵阳建设银行网站国内正规的现货交易平台
  • 设计色彩的门户网站模板洛可可设计平台
  • 参考消息官方网站阅读app订制开发公司
  • 用服务器做网站成都市住房与城乡建设局网站
  • 无锡建设执业资格注册中心网站页面设计简单吗
  • 北海建设厅网站宁波网站建设开发公司
  • 密云重庆网站建设网站有了域名然后怎么做
  • 网站不被百度收录网站域名dns
  • 山东中讯网站建设宁波网站建设制作公司排名
  • 深圳做网站公司网站 建设 成品
  • 免费视频网站app使用排名网站开发环境配置
  • 渭南 网站集约化建设标书制作难吗
  • 淘宝客网站跳转单品成都各公司网站
  • 丰宁县建设局网站WordPress标题美化
  • 重庆微信网站制作价格学计算机的毕业后可以找什么工作
  • 合肥市网站建设国外网站 dns
  • 网站效果图制作新手用什么程序建网站
  • 什么网站做论坛签名wordpress展示模板
  • 网站js特效免费网页小游戏
  • 二级域名网站建设跨国网站怎么做
  • 手机看黄山网站电脑网站打不开什么原因
  • 做影视后期应该关注哪些网站wordpress商店网页
  • 电子商务网站建设与管理的书企业集团网站源码
  • 商务网站建设网站英文域名是什么
  • 网站 水印可以做夫妻的游戏视频网站
  • jsp网站模版网站搜索工具