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

二刷 LeetCode:118. 杨辉三角 198. 打家劫舍 复盘笔记

目录一、118. 杨辉三角题目回顾思路复盘代码实现Java易错点 二刷心得二、198. 打家劫舍题目回顾思路复盘基础 DP 实现Java空间优化版O (1) 空间易错点 二刷心得三、两道题的共性总结 二刷收获这两道题分别是动态规划入门和经典一维 DP的代表也是面试高频考点。二刷时我们重点拆解思路、优化写法顺便把易错点和通用模板总结清楚。一、118. 杨辉三角题目回顾给定一个非负整数numRows生成「杨辉三角」的前numRows行。在「杨辉三角」中每个数是它左上方和右上方的数的和。思路复盘杨辉三角的核心规律第i行从 0 开始有i1个元素每行的第一个和最后一个元素都是1中间元素triangle[i][j] triangle[i-1][j-1] triangle[i-1][j]代码实现Javajava运行public ListListInteger generate(int numRows) { ListListInteger result new ArrayList(); for (int i 0; i numRows; i) { ListInteger row new ArrayList(); // 每行首尾为1 for (int j 0; j i; j) { if (j 0 || j i) { row.add(1); } else { // 中间元素 上一行的两个元素之和 row.add(result.get(i-1).get(j-1) result.get(i-1).get(j)); } } result.add(row); } return result; }易错点 二刷心得索引处理注意行号从 0 开始第i行的长度是i1避免越界。边界元素每行首尾元素必须单独处理为 1否则会出现i-1或j-1为负的越界错误。空间优化如果题目只要求返回第k行可以用一维数组滚动更新空间复杂度从 O (n²) 降到 O (n)。二、198. 打家劫舍题目回顾你是一个专业的小偷计划偷窃沿街的房屋。每间房内都藏有一定的现金影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统如果两间相邻的房屋在同一晚上被小偷闯入系统会自动报警。给定一个代表每个房屋存放金额的非负整数数组计算你不触动警报装置的情况下一夜之内能够偷窃到的最高金额。思路复盘这是一维动态规划的经典题核心是定义状态和状态转移方程。状态定义dp[i]表示前i间房屋能偷窃到的最高金额。状态转移对于第i间房屋有两种选择偷第i间那么不能偷第i-1间最高金额为dp[i-2] nums[i]不偷第i间最高金额为dp[i-1]状态转移方程dp[i] max(dp[i-1], dp[i-2] nums[i])初始状态dp[0] nums[0]只有一间房偷它dp[1] max(nums[0], nums[1])两间房偷金额大的结果dp[n-1]n 为房屋数量基础 DP 实现Javajava运行public int rob(int[] nums) { if (nums null || nums.length 0) return 0; if (nums.length 1) return nums[0]; int n nums.length; int[] dp new int[n]; dp[0] nums[0]; dp[1] Math.max(nums[0], nums[1]); for (int i 2; i n; i) { dp[i] Math.max(dp[i-1], dp[i-2] nums[i]); } return dp[n-1]; }空间优化版O (1) 空间因为dp[i]只依赖dp[i-1]和dp[i-2]所以可以用两个变量滚动更新空间复杂度从 O (n) 降到 O (1)java运行public int rob(int[] nums) { if (nums null || nums.length 0) return 0; if (nums.length 1) return nums[0]; int prevPrev nums[0]; int prev Math.max(nums[0], nums[1]); for (int i 2; i nums.length; i) { int current Math.max(prev, prevPrev nums[i]); prevPrev prev; prev current; } return prev; }易错点 二刷心得边界处理数组长度为 0 或 1 时要单独判断避免索引越界。状态转移的理解dp[i]表示前i间的最高金额不是偷第i间的最高金额所以不偷第i间时dp[i] dp[i-1]。空间优化技巧一维 DP 中如果当前状态只依赖前两个状态就可以用变量代替数组大幅降低空间复杂度。三、两道题的共性总结 二刷收获动态规划的入门模板杨辉三角二维 DP 的基础从简单的递推关系入手理解 “上一行推导下一行” 的思路。打家劫舍一维 DP 的经典学会定义状态、找到转移方程理解 “选 / 不选” 两种决策的逻辑。优化意识从二维数组到一维数组再到变量滚动更新体会空间优化的思路。二刷时不仅要写出正确的代码还要思考如何优化时间和空间复杂度。面试重点杨辉三角重点是边界处理和递推关系常作为 DP 入门题考察。打家劫舍重点是状态转移方程和空间优化后续的环形打家劫舍、打家劫舍 III 都是它的变形题。

相关文章:

二刷 LeetCode:118. 杨辉三角 198. 打家劫舍 复盘笔记

目录 一、118. 杨辉三角 题目回顾 思路复盘 代码实现(Java) 易错点 & 二刷心得 二、198. 打家劫舍 题目回顾 思路复盘 基础 DP 实现(Java) 空间优化版(O (1) 空间) 易错点 & 二刷心得 …...

《AI大模型应用开发实战从入门到精通共60篇》031、多模态大模型入门:CLIP、BLIP与LLaVA原理浅析

031、多模态大模型入门:CLIP、BLIP与LLaVA原理浅析 上周帮团队排查一个图文检索系统的线上bug,现象很诡异:用户上传一张“红色跑车在雪地”的图片,系统返回的文本描述居然是“白色轿车在沙滩”。我盯着日志看了半小时,…...

Matlab数据导出踩坑实录:writetable处理中文、日期和特殊字符的完整避坑指南

Matlab数据导出避坑实战:writetable处理多语言数据的7个关键技巧 上周在整理中日韩三语混合的传感器数据集时,我遇到了一个令人抓狂的问题——用writetable导出的CSV文件在Excel中打开全是乱码,而用记事本查看却显示正常。这个看似简单的数据…...

Windows运行安卓应用终极指南:告别模拟器的轻量级解决方案

Windows运行安卓应用终极指南:告别模拟器的轻量级解决方案 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 你是否厌倦了在电脑上安装臃肿的安卓模拟器&…...

如何高效部署DCNv4:终极可变形卷积实践指南

如何高效部署DCNv4:终极可变形卷积实践指南 【免费下载链接】DCNv4 [CVPR 2024] Deformable Convolution v4 项目地址: https://gitcode.com/gh_mirrors/dc/DCNv4 DCNv4(Deformable Convolution v4)是OpenGVLab发布的最新可变形卷积架…...

3步实现macOS鼠标滚动顺滑如触控板的终极方案

3步实现macOS鼠标滚动顺滑如触控板的终极方案 【免费下载链接】Mos 一个用于在 macOS 上平滑你的鼠标滚动效果或单独设置滚动方向的小工具, 让你的滚轮爽如触控板 | A lightweight tool used to smooth scrolling and set scroll direction independently for your mouse on ma…...

驾驭工程效率:模块化工具箱如何标准化开发运维实践

1. 项目概述:一个工程师的“瑞士军刀”工具箱最近在GitHub上看到一个挺有意思的项目,叫nnabuuu/harness-engineering-toolkit。光看名字,harness这个词就挺有味道的,它既有“利用、驾驭”的意思,也指代“线束、装备”。…...

ARMv8/v9异常处理机制与ESR_EL2寄存器解析

1. ARM异常处理机制概述异常处理是现代处理器架构的核心功能之一,它使系统能够响应硬件或软件产生的各类异常事件。在ARMv8/v9架构中,异常处理机制经过精心设计,特别是在支持虚拟化的场景下,提供了多层次的精细控制能力。当处理器…...

使用 curl 命令直接测试 Taotoken 接口连通性与模型返回效果

使用 curl 命令直接测试 Taotoken 接口连通性与模型返回效果 1. 准备工作 在开始测试之前,请确保您已具备以下条件:一个有效的 Taotoken API Key,该 Key 可在 Taotoken 控制台中创建;目标模型的 ID,可在模型广场查看…...

R 4.5新增s2_geometry()函数实测:全球10亿点集距离计算耗时从47分钟降至89秒(附基准测试完整复现代码)

更多请点击: https://intelliparadigm.com 第一章:R 4.5地理空间分析增强概览 R 4.5 版本在地理空间分析领域引入了多项底层优化与接口扩展,显著提升了 sf、terra 和 stars 等核心包的互操作性与性能表现。特别是对 PROJ 9.3 的原生支持&…...

企业如何利用 Taotoken 的审计日志功能管理内部 API 使用合规

企业如何利用 Taotoken 的审计日志功能管理内部 API 使用合规 1. 企业 API 使用合规的挑战 在企业环境中,大模型 API 的调用往往涉及多个团队和项目。缺乏有效的监控手段会导致资源分配不透明、成本难以控制,甚至可能引发未授权的模型使用行为。传统的…...

Illustrator脚本集:释放Adobe Illustrator隐藏生产力的10个实用工具

Illustrator脚本集:释放Adobe Illustrator隐藏生产力的10个实用工具 【免费下载链接】illustrator-scripts Adobe Illustrator scripts 项目地址: https://gitcode.com/gh_mirrors/il/illustrator-scripts 你是否曾经在Adobe Illustrator中重复执行繁琐操作&…...

XAPK转APK终极指南:3分钟搞定Android应用安装难题

XAPK转APK终极指南:3分钟搞定Android应用安装难题 【免费下载链接】xapk-to-apk A simple standalone python script that converts .xapk file into a normal universal .apk file 项目地址: https://gitcode.com/gh_mirrors/xa/xapk-to-apk 你是否曾经遇到…...

深入UVM数据流:从Transaction到Scoreboard的TLM通信实战解析

UVM数据流深度解析:从Transaction到Scoreboard的完整通信机制 在芯片验证领域,UVM(Universal Verification Methodology)已经成为事实上的标准验证方法学。对于已经搭建过简单UVM环境的工程师而言,理解数据如何在验证平…...

通过 Taotoken 用量看板清晰追踪各项目模型消耗与成本分摊情况

通过 Taotoken 用量看板清晰追踪各项目模型消耗与成本分摊情况 1. 用量看板的核心价值 对于同时接入多个大模型的项目团队而言,准确掌握各模型的调用量与费用分布是成本治理的基础。Taotoken 用量看板提供按项目、按模型、按时间维度的细粒度统计,帮助…...

通过Taotoken CLI工具一键配置团队开发环境与模型密钥

通过Taotoken CLI工具一键配置团队开发环境与模型密钥 1. CLI工具安装与基本使用 Taotoken提供的CLI工具可通过npm全局安装或直接使用npx运行。对于需要频繁使用CLI的团队,推荐全局安装: npm install -g taotoken/taotoken对于临时使用或项目级配置&a…...

4月30日阿里发布两款Agent产品,QoderWake邀测开启,提效显著或催生超级个体与组织

4月30日,阿里发布数字员工QoderWake和Qoder移动端两款Agent产品,覆盖企业和个人场景。QoderWake邀测已开启,能承担多岗位角色,提效明显。发布背景:现有Agent提效遇瓶颈最近数月,OpenClaw等通用Agent工具提升…...

如何快速计算3D模型体积和重量:STL-Volume-Model-Calculator终极指南

如何快速计算3D模型体积和重量:STL-Volume-Model-Calculator终极指南 【免费下载链接】STL-Volume-Model-Calculator STL Volume Model Calculator Python 项目地址: https://gitcode.com/gh_mirrors/st/STL-Volume-Model-Calculator 你是否曾经为3D打印项目…...

告别U盘和光盘!用iSCSI虚拟硬盘给服务器装Kylin V10 SP1,保姆级配置流程

基于iSCSI的银河麒麟V10 SP1无盘部署全流程解析 在数据中心和服务器机房中,传统的光盘或U盘安装方式正逐渐被更高效的网络部署方案取代。想象一下,当需要为数十台服务器批量安装操作系统时,不再需要逐个插入安装介质,而是通过简单…...

仅限前200名车载开发者获取:Dify车规版定制内核补丁包(含SPI Flash磨损均衡优化+看门狗协同重启模块)

更多请点击: https://intelliparadigm.com 第一章:Dify车载智能问答系统开发概述 Dify 是一个开源的低代码大模型应用开发平台,支持快速构建具备上下文感知、多轮对话与知识增强能力的智能问答系统。在车载场景中,其轻量级部署能…...

2026年程序员薪资被AI产品经理“碾压”?80万年薪的秘密都在这!

2026年AI产品经理成为薪资增长最快、人才缺口最大的岗位,3年经验者年薪可达80-100万元。文章分析了AI产品经理的三大核心类型(技术深耕型、垂直领域型、全生命周期型)及能力要求,揭示了薪资增长的关键因素(技术深度、业…...

全平台智能资源下载工具:res-downloader 完整使用教程

全平台智能资源下载工具:res-downloader 完整使用教程 【免费下载链接】res-downloader 视频号、小程序、抖音、快手、小红书、直播流、m3u8、酷狗、QQ音乐等常见网络资源下载! 项目地址: https://gitcode.com/GitHub_Trending/re/res-downloader res-downlo…...

从零部署OpenClaw AI助手:托管与自建方案全解析

1. 项目概述:从零到一,部署你的专属AI助手服务器如果你对AI助手的概念还停留在网页聊天框,那么OpenClaw可能会颠覆你的认知。它不是一个简单的聊天机器人,而是一个能运行在你自己的服务器上,拥有完整文件系统访问、代码…...

浏览器扩展开发实战:从DOM解析到文件下载,打造AI对话存档工具

1. 项目概述:一个被低估的“对话存档”利器如果你和我一样,经常在Phind这类AI编程助手工具上进行深度对话,那么你一定遇到过这样的痛点:花了几个小时和AI探讨一个复杂的技术方案,从架构设计到代码实现,再到…...

Xenos DLL注入器:5分钟解决Windows进程注入难题

Xenos DLL注入器:5分钟解决Windows进程注入难题 【免费下载链接】Xenos Windows dll injector 项目地址: https://gitcode.com/gh_mirrors/xe/Xenos 你是否曾经面对Windows进程注入的复杂操作感到无从下手?想象一下,你需要测试一个自定…...

手把手教你逆向分析携程旅行App的私有TCP协议(附So库解密实战)

深度解析移动应用私有TCP协议逆向工程实战 在移动互联网时代,应用开发者越来越重视数据传输的安全性,许多主流应用如携程旅行等纷纷采用私有TCP协议替代标准HTTP协议进行通信。这种变化给安全研究人员、数据工程师和技术爱好者带来了新的挑战——当传统抓…...

Sunshine游戏串流终极指南:如何用开源方案实现全平台游戏自由?

Sunshine游戏串流终极指南:如何用开源方案实现全平台游戏自由? 【免费下载链接】Sunshine Self-hosted game stream host for Moonlight. 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine Sunshine是一个强大的自托管游戏串流服务器&…...

第8章(2)——项目二:Claude与显示思考——引用资料

第8章(2)——项目二:Claude与显示思考——引用资料8.8 metadata显示思考的工具和资料8.8.1 metadata显示思考——使用工具8.8.2 项目二:Claude与显示思考——引用资料8.8 metadata显示思考的工具和资料 gr.Chatbot组件支持参数me…...

分享16个精美网站后台登录注册页面源码 总有几款适合你

内容目录一、详细介绍二、效果展示1.部分代码2.效果图展示一、详细介绍 在开发网站后台系统时,登录注册页面作为用户与系统交互的第一步,其设计的好坏直接影响用户体验。一个美观、易用的登录注册页面能够提升用户对系统的好感度和信任度。今天&#xf…...

3D打印企业还需要转型?这三个案例给出重要启示!

当前,金属3D打印技术正在全球范围内经历关键转折——从原型、小批量零件制造,加速迈向真正的大批量、高性能最终产品制造。在这一阶段,市场竞争也变得异常激烈。各家品牌在技术路线、产品参数和服务模式上出现巨大的同质化。无论是消费级打印…...