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

20天速通LeetCode day07:前缀和

前言今日练习目的掌握前缀和思维。前缀和的核心价值是能实现在O(1)时间求区间和是各类子数组问题的常用工具560和为k的子数组题目要求给定一个整数数组nums和整数k要求统计并返回和为k的子数组核心思路前缀和哈希表利用前缀和sum[i]表示数组前i个元素和结合哈希表优化定义sum[i]表示前i个元素和一个子数组[j1,i]的和为k等价于sum[i]−sum[j]k⇒sum[j]sum[i]−k用一个哈希表map记录前缀和出现的次数代码实现classSolution{publicintsubarraySum(int[]nums,intk){MapInteger,IntegerprefixSumnewHashMap();prefixSum.put(0,1);// 初始化前缀和 0 出现一次intcount0;intcurrSum0;for(intnum:nums){currSumnum;// 更新前缀和// 如果存在前缀和 currSum - k则说明找到一个子数组countprefixSum.getOrDefault(currSum-k,0);// 更新哈希表prefixSum.put(currSum,prefixSum.getOrDefault(currSum,0)1);}returncount;}}总结本题本质通过前缀和哈希表的方式。哈希表用来统计前缀和出现的次数本题有点像两数之和都是用哈希表快速查找差值不同点在于两数之和是找出下标本题是统计出现的次数209长度最小的子数组题目要求给定一个正整数数组nums和一个整数target要求找出长度最小的连续子数组使得子数组元素之和target。不存在则返回0核心思路前缀和二分查找用前缀和快速求区间和将问题转化为二分查找找出 最小的右边界 j使用Arrays.binarySearch 找 j代码实现classSolution{publicintminSubArrayLen(inttarget,int[]nums){intnnums.length;int[]prefixnewint[n1];//计算前缀和for(inti0;in;i){prefix[i1]prefix[i]nums[i];}intminLenInteger.MAX_VALUE;//遍历每个左边界for(inti0;in;i){intkeyprefix[i]target;//二分查找最小j使prefix[j]keyintjArrays.binarySearch(prefix,key);if(j0){// binarySearch 返回 -(插入点)-1j-j-1;}if(jn){minLenMath.min(minLen,j-i);}}returnminLenInteger.MAX_VALUE?0:minLen;}}238除了自身以外数组的乘积题目要求给定一个整数数组nums返回一个数组answer要求answer[i]nums 中除 nums[i] 之外所有元素的乘积核心思路前缀积prefix[i]表示nums[0…i-1]的乘积后缀积suffix[i]表示nums[i1…n-1]的乘积那么answer[i]prefix[i]*suffix[i]代码实现publicint[]productExceptSelf(int[]nums){intnnums.length;int[]answernewint[n];// 前缀积answer[0]1;for(inti1;in;i){answer[i]answer[i-1]*nums[i-1];}// 后缀积intR1;for(intin-1;i0;i--){answer[i]answer[i]*R;R*nums[i];}returnanswer;}总结核心技巧用前缀积记录左边乘积用后缀积记录右边乘积相乘即可得到每个位置除自身外的乘积优化空间先存前缀积在 answer用一个变量 R 代替后缀积数组

相关文章:

20天速通LeetCode day07:前缀和

前言 今日练习目的:掌握前缀和思维。前缀和的核心价值是能实现在O(1)时间求区间和,是各类子数组问题的常用工具 560:和为k的子数组 题目要求:给定一个整数数组nums和整数k 要求:统计并返回和为k的子数组 核心思路&…...

给数学恐惧者的图解:用几何直觉理解SVM中的对偶问题与KKT条件

给数学恐惧者的图解:用几何直觉理解SVM中的对偶问题与KKT条件 第一次接触支持向量机(SVM)时,很多人都会被"对偶问题"和"KKT条件"这两个概念吓退。教科书上密密麻麻的数学推导让人望而生畏,仿佛在提…...

Python实战:从零实现Transformer中的多头注意力机制

1. 理解多头注意力机制的核心思想 多头注意力机制是Transformer架构中最关键的组成部分之一,它让模型能够同时关注输入序列的不同位置,并学习到丰富的上下文信息。想象一下你在阅读一篇文章时,大脑会同时关注当前句子、前文提到的关键概念&am…...

Jupyter Notebook代码补全插件安装踩坑实录:从nbextensions不显示到完美解决(Anaconda环境)

Jupyter Notebook代码补全插件安装踩坑实录:从nbextensions不显示到完美解决(Anaconda环境) 在数据科学和机器学习的工作流中,Jupyter Notebook因其交互式特性广受欢迎,而代码补全功能能显著提升开发效率。然而&#x…...

若依WMS仓库管理系统:企业级仓储管理的现代化解决方案

若依WMS仓库管理系统:企业级仓储管理的现代化解决方案 【免费下载链接】RuoYi-WMS-VUE 若依wms是一套基于若依的wms仓库管理系统,支持lodop和网页打印入库单、出库单。包括仓库/库区/货架管理,出入库管理,客户/供应商/承运商&…...

从零搭建思澈科技SiFli-Solution开发环境:避坑指南与实战演练

1. 环境准备:软件工具全家桶 第一次接触思澈科技的SiFli-Solution平台时,我像个刚拿到乐高套装的孩子——既兴奋又手足无措。这里给各位新手列个必备工具清单,都是我踩坑后验证过的稳定组合:Keil uVision5(5.32版&…...

Python实现图形化井字棋——人机对战

井字棋,英文名叫TicQ-Tac-Toe,是一种在3*3格子上进行的连珠游戏,和五子棋类似,由于棋盘一般不画边框,格线排成井字故得名。游戏需要的工具仅为纸和笔,然后由分别代表O和X的两个游戏者轮流在格子里留下标记&…...

MOPSO算法实战:如何用它搞定你的多目标优化项目?(从理论到调参全解析)

MOPSO算法实战:从理论到调参的全流程指南 想象一下你正面临一个棘手的工程优化问题——需要在云计算资源调度中同时优化成本和性能。传统的单目标优化方法让你不得不在两个相互冲突的目标之间做出妥协,而多目标粒子群优化(MOPSO)…...

5分钟上手LogcatReader:安卓设备日志查看神器

5分钟上手LogcatReader:安卓设备日志查看神器 【免费下载链接】LogcatReader A simple app for viewing logcat logs on an android device. 项目地址: https://gitcode.com/gh_mirrors/lo/LogcatReader 还在为复杂的ADB命令而烦恼吗?LogcatReade…...

【2026奇点智能技术大会权威解码】:AI原生数据结构生成的5大范式跃迁与工程落地路径

第一章:2026奇点智能技术大会:AI数据结构生成 2026奇点智能技术大会(https://ml-summit.org) 核心突破:语义驱动的数据结构合成引擎 本届大会首次公开发布StructGen v3.1——一个基于多模态推理与形式化约束求解的AI数据结构生成框架。它不…...

科学图像分析难题破解:3个步骤让Fiji成为你的得力助手

科学图像分析难题破解:3个步骤让Fiji成为你的得力助手 【免费下载链接】fiji A "batteries-included" distribution of ImageJ :battery: 项目地址: https://gitcode.com/gh_mirrors/fi/fiji 你是否曾经面对显微镜下的大量细胞图像束手无策&#x…...

英雄联盟智能工具箱:重新定义你的游戏体验

英雄联盟智能工具箱:重新定义你的游戏体验 【免费下载链接】League-Toolkit An all-in-one toolkit for LeagueClient. Gathering power 🚀. 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit 在英雄联盟的竞技世界中,每一…...

【限时解密】GitHub Copilot Enterprise未公开的3项性能开关:启用后P99延迟下降63%,仅限前500名开发者获取配置清单

第一章:智能代码生成性能优化技巧 2026奇点智能技术大会(https://ml-summit.org) 智能代码生成模型(如基于LLM的Copilot类工具)在实际工程落地中常面临响应延迟高、上下文吞吐低、生成结果不稳定等问题。优化其端到端性能需兼顾推理效率、缓…...

YOLO优化|轻量化注意力机制实战对比

1. 为什么YOLO需要轻量化注意力机制? 在移动端和边缘计算场景下部署目标检测模型时,我们常常面临两个核心矛盾:计算资源有限和实时性要求高。以智能手机上的AR应用为例,处理1080P图像通常需要在30ms内完成推理,这对传统…...

ESP-12F腾讯云MQTT固件烧录避坑指南:常见问题与解决方案

ESP-12F腾讯云MQTT固件烧录实战:从问题排查到稳定连接 最近在帮朋友调试一个智能家居项目时,遇到了ESP-12F模块连接腾讯云MQTT服务器的问题。原本以为只是简单的固件烧录,没想到在实际操作中踩了不少坑。这篇文章将分享我在解决这些问题时积…...

Kali Linux实战:用SET工具包5分钟克隆一个钓鱼网站(附谷歌浏览器登录凭证捕获演示)

Kali Linux实战:5分钟构建钓鱼网站与凭证捕获全流程 在网络安全领域,渗透测试工具的应用能力直接决定了安全防护的有效性。Social Engineer Toolkit(SET)作为Kali Linux中的明星工具包,以其高度集成化和易用性著称&am…...

乐视三合一体感摄像头Astra pro开发实践2(多平台环境配置与数据采集优化)

1. 多平台环境配置实战 乐视三合一体感摄像头Astra Pro确实是个性价比超高的开发设备,我在Windows和Ubuntu双系统下都折腾过它的环境配置。先说Windows平台,最容易踩坑的就是OpenNI2的驱动问题。第一次安装时直接从GitHub下载了OpenNI2,结果死…...

从理论到实践:用PROTUES快速验证差分放大电路的计算公式

从理论到实践:用PROTUES快速验证差分放大电路的计算公式 在电子工程领域,差分放大电路的设计与验证是一个绕不开的经典课题。作为模拟电路设计的基石,它完美诠释了"抑制共模干扰,放大差模信号"这一核心理念。然而&#…...

STM32F407以太网实战:用CubeMX配置LWIP实现UDP通信(附YT8512C PHY避坑指南)

STM32F407以太网开发实战:从CubeMX配置到YT8512C PHY芯片深度适配指南 在嵌入式系统开发中,以太网通信功能的实现往往是最具挑战性的任务之一。当开发板搭载的不是常见的LAN8742这类主流PHY芯片,而是YT8512C等非标准型号时,工程师…...

【SITS2026官方认证指南】:AI文档生成工具选型、落地与合规避坑的7大黄金法则

第一章:SITS2026官方认证框架下的AI文档生成工具全景认知 2026奇点智能技术大会(https://ml-summit.org) 在SITS2026(Software Intelligence & Trustworthiness Standard 2026)官方认证体系中,AI文档生成工具不再仅是辅助写作…...

用STM32CubeMX和HAL库5分钟搞定BMP280气压传感器驱动(附完整代码)

STM32CubeMX与HAL库快速集成BMP280气压传感器的完整指南 气压传感器在现代嵌入式系统中扮演着重要角色,从无人机高度控制到气象站数据采集,BMP280凭借其高精度和稳定性成为工程师的热门选择。传统寄存器级开发方式虽然灵活,但对于追求开发效率…...

从多模态到模型之争:Java开发者的AI认知升级与转型指南

写在前面“多模态是什么?ChatGPT和DeepSeek到底有什么区别?在现在AI浪潮的冲击下,我作为一个Java后端开发者,到底要不要学AI?”这是很多Java开发者正在面对的困惑。AI领域日新月异,概念层出不穷&#xff0c…...

IndexTTS2:免费开源的情感可控零样本语音合成系统终极指南

IndexTTS2:免费开源的情感可控零样本语音合成系统终极指南 【免费下载链接】index-tts An Industrial-Level Controllable and Efficient Zero-Shot Text-To-Speech System 项目地址: https://gitcode.com/gh_mirrors/in/index-tts 你是否在为视频配音时苦恼…...

如何用Python脚本完整备份你的QQ空间历史说说:终极免费方案

如何用Python脚本完整备份你的QQ空间历史说说:终极免费方案 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 你是否曾担心那些记录青春岁月的QQ空间说说会随着时间消失&#…...

2025最权威的降重复率助手横评

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 对文本结构做合理调整,努力避免模板化句式,全力融入个人特别见解与非…...

别再对着AD7705手册发愁了!手把手教你用STM32CubeMX配置SPI驱动(附完整代码)

STM32CubeMX实战:5分钟搞定AD7705高精度ADC驱动开发 在嵌入式系统开发中,ADC模块的选择和驱动开发往往是硬件工程师的痛点。AD7705作为一款16位Σ-Δ型ADC芯片,以其高精度和低噪声特性在工业测量领域广受欢迎。但传统的手动寄存器配置方式不仅…...

高效日志分析解决方案:glogg 专业日志查看器的企业级应用指南

高效日志分析解决方案:glogg 专业日志查看器的企业级应用指南 【免费下载链接】glogg A fast, advanced log explorer. 项目地址: https://gitcode.com/gh_mirrors/gl/glogg 在复杂的分布式系统和微服务架构中,海量日志数据的实时分析与检索已成为…...

跨平台资源拦截下载器:5步实现全平台视频音频自动捕获

跨平台资源拦截下载器:5步实现全平台视频音频自动捕获 【免费下载链接】res-downloader 视频号、小程序、抖音、快手、小红书、直播流、m3u8、酷狗、QQ音乐等常见网络资源下载! 项目地址: https://gitcode.com/GitHub_Trending/re/res-downloader 在数字内容…...

Cadence Virtuoso 6.17 保姆级教程:手把手教你完成一个简单放大器的瞬态仿真

Cadence Virtuoso 6.17 保姆级教程:手把手教你完成一个简单放大器的瞬态仿真 刚接触模拟IC设计时,最令人头疼的莫过于面对复杂的EDA工具却不知从何下手。Cadence Virtuoso作为行业标准工具,功能强大但学习曲线陡峭。本文将用最直观的方式&…...

别再瞎选了!手把手教你为Zynq MPSOC项目选对AXI接口:ACP、HPC还是HP?

Zynq MPSoC三大AXI接口深度实战:从架构原理到选型决策 在Zynq MPSoC的软硬件协同设计中,AXI接口选型直接决定了系统性能天花板。当你在Vivado中看到ACP、HPC、HP这三个并排的AXI从接口时,是否曾困惑过它们真正的差异?本文将通过实…...