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

代码随想录算法训练营第三九天| 198.打家劫舍 213.打家劫舍II 337.打家劫舍 III

今日任务

198.打家劫舍
213.打家劫舍II
337.打家劫舍 III


198.打家劫舍

题目链接: . - 力扣(LeetCode)

class Solution {public int rob(int[] nums) {int[] dp = new int[nums.length];if (nums.length == 1) return nums[0];if (nums.length == 2) return Math.max(nums[0], nums[1]);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 - 2] + nums[i], dp[i - 1]);}return dp[nums.length - 1];}
}

213.打家劫舍II

题目链接: . - 力扣(LeetCode)

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


337.打家劫舍 III

题目链接: . - 力扣(LeetCode)

/*** 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[] result = robTree(root);return Math.max(result[0], result[1]);}// 0-不偷 1-偷int[] robTree(TreeNode root) {if (root == null) return new int[]{0, 0};int[] left = robTree(root.left);int[] right = robTree(root.right);//偷当前节点,那就不能偷左右节点int val1 = root.val + left[0] + right[0];//不偷当前节点,那左右节点可投可不投,取大值int val2 = Math.max(left[0], left[1]) + Math.max(right[0], right[1]);return new int[]{val2, val1};}    
}


 

http://www.lryc.cn/news/443194.html

相关文章:

  • 阿里云AI基础设施全面升级,模型算力利用率提升超20%
  • Debezium日常分享系列之:将容器镜像移至 quay.io
  • 基于TCP实现聊天
  • 基于JavaSwing实现的酒店管理系统
  • 网络基础,协议,OSI分层,TCP/IP模型
  • CefSharp_Vue交互(Element UI)_WinFormWeb应用---设置应用透明度(含示例代码)
  • 【OSS安全最佳实践】降低因账号密码泄露带来的未授权访问风险
  • 视频存储EasyCVR视频监控汇聚管理平台设备录像下载报错404是什么原因?
  • 在Spring项目中,两个实用的工具(生成类与映射文件、API自动生成)
  • C#基础(16)实践:学生成绩管理系统
  • git常用命令(patch补丁和解决冲突)
  • 数模方法论-整数规划
  • 【问题随记】在使用 AuthenticationManager 的时候,出现循环依赖问题 —— `java.lang.StackOverflowError`
  • 2024年华为杯-研赛F题论文问题一二讲解+代码分享
  • 代码随想录训练营第34天|dp前置转移
  • 乐观锁、悲观锁
  • Java客户端SpringDataRedis(RedisTemplate使用)
  • wsl2桥接网络 ubuntu到弃坑到又跳坑
  • WIFI路由器的套杆天线简谈
  • 希尔排序(C语言实现)
  • LLVM 中的Value、User、Use设计
  • C++智能指针入门教程(C++11)
  • 常用工具推荐!分享7款AI论文修改软件工具网站
  • 怎么解除BitLocker对磁盘的加密?
  • 群晖使用Docker部署WPS Office并实现异地使用浏览器制作办公文档
  • Unity3d 以鼠标位置点为中心缩放视角(正交模式下)
  • Git清除某文件所有历史提交记录
  • jacoco生成单元测试覆盖率报告
  • 【CSS Tricks】如何做一个粒子效果的logo
  • 如何使用ssm实现基于Javaweb的网上花店系统的设计与实现