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

学做网站有没有前途怎样建立一个网站步骤

学做网站有没有前途,怎样建立一个网站步骤,开发公司对物业公司的考核,成都电子商务网站建站力扣爆刷第77天–动态规划一网打尽打家劫舍问题 文章目录 力扣爆刷第77天--动态规划一网打尽打家劫舍问题一、198.打家劫舍二、213.打家劫舍II三、337.打家劫舍 III 一、198.打家劫舍 题目链接:https://leetcode.cn/problems/house-robber/ 思路:小偷不…

力扣爆刷第77天–动态规划一网打尽打家劫舍问题

文章目录

      • 力扣爆刷第77天--动态规划一网打尽打家劫舍问题
      • 一、198.打家劫舍
      • 二、213.打家劫舍II
      • 三、337.打家劫舍 III

一、198.打家劫舍

题目链接:https://leetcode.cn/problems/house-robber/
思路:小偷不能连续两家偷,由此可以定义dp[i]表示,小偷经过[0,i]所能获取到的最大金额,那么我们可以得到递推公式:
dp[i] = Math.max(dp[i-1], dp[i-2]+nums[i]);
即如果偷nums[i]家就不能偷前一家,为dp[i-2]+nums[i],如果不偷当前这家,那金额就要维持为经过前一家时的结果。
很简单的题目,标准的动态规划,进行状态选择。
标准写法

class Solution {public int rob(int[] nums) {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];}
}

优化写法

class Solution {public int rob(int[] nums) {if (nums.length == 1) return nums[0];int a = nums[0], b= Math.max(nums[0], nums[1]);for (int i = 2; i < nums.length; i++) {int c = Math.max(b, a+nums[i]);a = b;b = c;}return b;}
}

二、213.打家劫舍II

题目链接:https://leetcode.cn/problems/house-robber-ii/
思路:本题和上一题不同之处是房间首尾相连,那么也很简单,直接从两个范围求,第一个范围[0, len-1], 第二个范围[1, len],分别从这两个范围,一个只含头,一个只含尾,其他的和上一题一样。

class Solution {public int rob(int[] nums) {if(nums.length == 1) return nums[0];if(nums.length == 2) return Math.max(nums[0], nums[1]);return Math.max(getMax(nums, 0, nums.length-1), getMax(nums, 1, nums.length));}int getMax(int[] nums, int s, int e) {int[] dp = new int[nums.length];dp[s] = nums[s];dp[s+1] = Math.max(nums[s], nums[s+1]);for(int i = s+2; i < e; i++) {dp[i] = Math.max(dp[i-1], dp[i-2]+nums[i]);}return dp[e-1];}
}

三、337.打家劫舍 III

题目链接:https://leetcode.cn/problems/house-robber-iii/description/
思路:二叉树形态的打家劫舍,其实也很简单,每个节点有两种状态分别是抢不与抢,后序遍历返回dp数组,有了左右子树的dp数组即可计算当前节点的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[] dp = traverse(root);return Math.max(dp[0], dp[1]);}// 0 偷 1 不偷int[] traverse(TreeNode root) {if(root == null) return new int[2];int[] left = traverse(root.left);int[] right = traverse(root.right);int[] dp = new int[2];dp[0] = root.val + left[1] + right[1];dp[1] = Math.max(left[0], left[1]) + Math.max(right[0], right[1]);return dp;      }}
http://www.yayakq.cn/news/97644/

相关文章:

  • 网站建设职业情况建e室内设计网址
  • 汕头企业建站系统第三方小程序开发平台有哪些
  • 天通苑网站建设免费网站建站手机
  • 怎么自己写代码做网站外贸网站 英文
  • 广东智能网站建设哪家有wordpress 后台菜单修改
  • 盘锦威旺做网站建设建设银行官方网站电子银行登录
  • 做网站编辑需要看什么书织梦做的网站在百度搜索页劫取
  • 高端it网站建设软件开发做网站
  • 网站模板下载后如何使用strange wordpress主题
  • 小型企业网站建设报告模拟组建过程wordpress是否免费
  • asp.net网站开发介绍电商培训机构排名前十
  • 汕头市广州新业建设有限公司网站寻找做网站的合作伙伴北京
  • 网站由谁备案wordpress 内容采集
  • 服装厂网站模板江苏宜兴做网站的电话
  • 高校网站建设管理制度网站项目建设背景
  • 赛门仕博做网站怎么样物流官网网站
  • 电子科技产品网站建设百度权重划分等级
  • 我帮你建站做外贸网站一般多少钱
  • 阿里云建设网站做网站在哪个地方买空间
  • 如何用word做网站u钙网logo设计影视剪辑
  • 长沙网站建设zh68模板网站建设珠海
  • 预约做家庭清洁的网站wordpress 生成
  • 房子如何上网站做民宿订阅号可以做网站链接吗
  • 怎样设置个人官方网站企业网站建设三网合一
  • 在市场部做网站多少工资如何在wordpress底部添加友情链接
  • 湛江企业网站怎么建设网站建设在360属于什么类目
  • 论坛型网站开发品牌商城网站建设
  • 企业网站优化服务公司做网站要写代码吗
  • 永康网站建设临清市住房和城乡建设局网站
  • 做网店网站成都专业网站设计免费咨询