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

Leetcode普通数组-day5、6

Leetcode普通数组-day5/6记录自己刷力扣备战秋招的刷题笔记❤️​ ——wosz普通数组普通数组没什么需要说的其实最简单的办法就是遍历因为普通数组它是连续的因此不会涉及到很复杂的算法。因为是遍历嘛我们就可以用到我们前面学习过的一些方法如双指针去减少遍历次数滑动窗口去实习相对应的数组处理最大子数组和给你一个整数数组nums请你找出一个具有最大和的连续子数组子数组最少包含一个元素返回其最大和。子数组是数组中的一个连续部分。**输入**nums [-2,1,-3,4,-1,2,1,-5,4]**输出**6**解释**连续子数组 [4,-1,2,1] 的和最大为 6 。自己题解classSolution{public:intmaxSubArray(vectorintnums){intnum_sizenums.size();intcur0;// 当前前缀和intmin_prevalue0;// 到当前位置之前最小的前缀和inttagnums[0];for(inti0;inum_size;i){curnums[i];//计算当前前缀和if(tagcur-min_prevalue)//当前前缀和减去之前最小前缀和{tagcur-min_prevalue;}if(curmin_prevalue){min_prevaluecur;}}returntag;}};我的思路受到前面做到一个关于子串的题是用的前缀和的方式这道题我想了一下感觉可以使用前缀和来解决。我们用当前前缀和减去之前最小前缀和就表示以当前位置结尾的最大子数组和。遍历一遍后取最大值即可。我一开始还想错了直接使用最大减去最小还去进行分段讨论呢官方题解classSolution{public:intmaxSubArray(vectorintnums){intpre0,maxAnsnums[0];for(constautox:nums){premax(prex,x);maxAnsmax(maxAns,pre);}returnmaxAns;}};官方我选取的是采用动态规划的题解因为我本人也没有学习过动态规划就趁机再学习一下动态规划。dp[i] 表示以nums[i]结尾的连续子数组的最大和。此时我们的考虑就是两种一种是1.前面的dp[i-1]nums[i]就是此时的dp 2.从自己开始num[i] (前面的和可能是负贡献)dp[i] max(dp[i-1] nums[i], nums[i])补充动态规划因为后面还会再次学所以这里我就大概简单先了解一下方便理解本题的动态规划解法动态规划从初始状态出发到经过一系列的状态转移到达目标状态的最优解。同时具有条件状态转移必须有方向同时整体不能成环状状态的个数必须要在可接收的范围内解题的几个重点dp数组就是表示状态要知道具体的下标是什么意思递推公式dp数组初始化遍历的一个顺序合并区间以数组intervals表示若干个区间的集合其中单个区间为intervals[i] [starti, endi]。请你合并所有重叠的区间并返回一个不重叠的区间数组该数组需恰好覆盖输入中的所有区间。**输入**intervals [[1,3],[2,6],[8,10],[15,18]]输出[[1,6],[8,10],[15,18]]**解释**区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6]自己题解classSolution{public:vectorvectorintmerge(vectorvectorintintervals){intnum_sizeintervals.size();sort(intervals.begin(),intervals.end());//先排序vectorvectorinttag;inttemp_endintervals[0][1];inttemp_startintervals[0][0];intindex10,index21;while(index2num_size){//判断if(intervals[index2][0]temp_end)//必定出现重合{if(temp_endintervals[index2][1]){temp_endintervals[index2][1];}if(temp_startintervals[index2][0]){temp_startintervals[index2][0];}}else{//出现不重合此时直接添加到结果同时移动index1tag.push_back({temp_start,temp_end});index1index2;temp_endintervals[index1][1];temp_startintervals[index1][0];}//扩张index2;}tag.push_back({temp_start,temp_end});//er:最后一个没有放returntag;}};我的思路其实我就准备使用双指针来解决先进行排序然后让 index1 去指向合并区间的起点让 index2 去不断扩张然后同时用值去记录当前和合并区间的末尾方便判断。之后如果遇到不可以可以合并的就将已经合并的添加到结果中去同时让 index1 直接移动到 index2 处让index2继续扩张持续。官方题解classSolution{public:vectorvectorintmerge(vectorvectorintintervals){if(intervals.size()0){return{};}sort(intervals.begin(),intervals.end());vectorvectorintmerged;for(inti0;iintervals.size();i){intLintervals[i][0],Rintervals[i][1];if(!merged.size()||merged.back()[1]L){merged.push_back({L,R});}else{merged.back()[1]max(merged.back()[1],R);}}returnmerged;}};思路是一致的都是先对数组进行排序然后比较首尾进行判断合并区间。轮转数组给定一个整数数组nums将数组中的元素向右轮转k个位置其中k是非负数。输入:nums [1,2,3,4,5,6,7], k 3输出:[5,6,7,1,2,3,4]解释:向右轮转 1 步: [7,1,2,3,4,5,6]向右轮转 2 步: [6,7,1,2,3,4,5]向右轮转 3 步: [5,6,7,1,2,3,4]自己题解classSolution{public:voidrotate(vectorintnums,intk){intnum_sizenums.size();vectorintnew_num(num_size,0);for(inti0;inum_size;i){inttemp(ik)%num_size;new_num[temp]nums[i];}//再来赋值for(inti0;inum_size;i){nums[i]new_num[i];}}};我的思路我感觉我有点苯我的想法就是新开一个数组然后直接进行位移进去就行我就是用求余的形式来进行按照indexk-1%size来进行位移计算就可以了。最后再来一次遍历就行确实感觉有点蠢了但是胜在简单啊。官方题解classSolution{public:voidreverse(vectorintnums,intstart,intend){while(startend){swap(nums[start],nums[end]);start1;end-1;}}voidrotate(vectorintnums,intk){k%nums.size();reverse(nums,0,nums.size()-1);reverse(nums,0,k-1);reverse(nums,k,nums.size()-1);}};官方的方法我就学习一下翻转法这个翻转法的意思就是多次翻转就可以实现数组的轮转大致的思路就是下面这样除了自身以外的数组乘积给你一个整数数组nums返回 数组answer其中answer[i]等于nums中除了nums[i]之外其余各元素的乘积 。题目数据保证数组nums之中任意元素的全部前缀元素和后缀的乘积都在32 位整数范围内。请 **不要使用除法**且在O(n)时间复杂度内完成此题。输入:nums [1,2,3,4]输出:[24,12,8,6]自己题解classSolution{public:vectorintproductExceptSelf(vectorintnums){intnum_sizenums.size();vectorintmy_v(num_size,1);intpre1;//前缀积//先计算前缀积for(inti0;inum_size;i){my_v[i]pre;pre*nums[i];}intlast1;//后缀积//计算后缀积for(intinum_size-1;i0;i--){my_v[i]*last;last*nums[i];}returnmy_v;}};我的思路拿到这道题之后自然而然的想到了两种方法1.直接所有乘起来然后依次除以每一个元素当然这道题不能用 2.直接暴力for循环进行判断一下这个下标条件即可当然不出意外我们这个的复杂度不满足会超出时间限制让AI给我提供了一下新思路就是前缀积和后缀积tag[i]前缀积*后缀积官方的题解classSolution{public:vectorintproductExceptSelf(vectorintnums){intlengthnums.size();// L 和 R 分别表示左右两侧的乘积列表vectorintL(length,0),R(length,0);vectorintanswer(length);// L[i] 为索引 i 左侧所有元素的乘积// 对于索引为 0 的元素因为左侧没有元素所以 L[0] 1L[0]1;for(inti1;ilength;i){L[i]nums[i-1]*L[i-1];}// R[i] 为索引 i 右侧所有元素的乘积// 对于索引为 length-1 的元素因为右侧没有元素所以 R[length-1] 1R[length-1]1;for(intilength-2;i0;i--){R[i]nums[i1]*R[i1];}// 对于索引 i除 nums[i] 之外其余各元素的乘积就是左侧所有元素的乘积乘以右侧所有元素的乘积for(inti0;ilength;i){answer[i]L[i]*R[i];}returnanswer;}};最经典的解法就是前缀积和后缀积这道题官方给出的也是这个解法进行的前缀积和后缀积的形式。缺失的第一个正数给你一个未排序的整数数组nums请你找出其中没有出现的最小的正整数。请你实现时间复杂度为O(n)并且只使用常数级别额外空间的解决方案。**输入**nums [1,2,0]**输出**3**解释**范围 [1,2] 中的数字都在数组中。我的题解classSolution{public:intfirstMissingPositive(vectorintnums){intnum_sizenums.size();unordered_mapint,intmap;inttag1;intflag0;for(inti0;inum_size;i){map[nums[i]]i;}//查找while(flag0){if(map.find(tag)!map.end()){tag;}else{flag1;}}returntag;}};我看到这个题的时候首先想到的就是哈希表查询然后时间复杂度应该是满足的但是空间不是常数级别。还想到一个就是先对数组进行排序之后利用双指针进行滑动应该也可以的。然后让AI大哥帮我修改了一下就用classSolution{public:intfirstMissingPositive(vectorintnums){intnnums.size();// 第一步把无关数字变成 n1// 因为我们只关心 1~nfor(inti0;in;i){if(nums[i]0||nums[i]n){nums[i]n1;}}// 第二步用下标做标记// 如果数字 x 出现过就把 nums[x-1] 标记成负数for(inti0;in;i){intxabs(nums[i]);if(x1xn){nums[x-1]-abs(nums[x-1]);}}// 第三步找第一个没被标记的位置for(inti0;in;i){if(nums[i]0){returni1;}}returnn1;}};因为我们要找到的是一个1~n之间所以直接把无关的数组变为n1之后就在原地实现桶的功能不用新开哈希表。官方题解classSolution{public:intfirstMissingPositive(vectorintnums){intnnums.size();for(intnum:nums){if(num0){numn1;}}for(inti0;in;i){intnumabs(nums[i]);if(numn){nums[num-1]-abs(nums[num-1]);}}for(inti0;in;i){if(nums[i]0){returni1;}}returnn1;}};这个官方的题解就是主要采用的原地桶查找和我们上面让AI修改的大致是一样的思路。我们对数组进行遍历对于遍历到的数 x如果它在[1,N]的范围内那么就将数组中的第x−1个位置注意数组下标从 0 开始打上「标记」。在遍历结束之后如果所有的位置都被打上了标记那么答案是N1否则答案是最小的没有打上标记的位置加 1。就是先将无关的数组去掉然后利用nums充当标记即可。

相关文章:

Leetcode普通数组-day5、6

Leetcode普通数组-day5/6记录自己刷力扣备战秋招的刷题笔记❤️ ​ ——wosz普通数组 普通数组没什么需要说的,其实最简单的办法就是遍历,因为普通数组它是连续的,因此不会涉及到很复杂的算法。 因为是遍历嘛,我们就可…...

LangChain教程-、Langchain基础来

简介 AI Agent 不仅仅是一个能聊天的机器人(如普通的 ChatGPT),而是一个能够感知环境、进行推理、自主决策并调用工具来完成特定任务的智能系统,更够完成更为复杂的AI场景需求。 AI Agent 功能 根据查阅的资料,agent的…...

Pokerobo_PSx:轻量级PS2手柄嵌入式驱动库

1. Pokerobo_PSx 库概述Pokerobo_PSx 是一个专为嵌入式系统设计的轻量级 PS2 DualShock 手柄通信协议栈,面向 STM32、ESP32、nRF52 等主流 MCU 平台,提供完整、稳定、可裁剪的 PlayStation 2 游戏手柄(含 DualShock 1/2 及兼容设备&#xff0…...

用 Microsoft Agent Framework 构建 SubAgent(Multi-Agent)伎

本文能帮你解决什么? 1. 搞懂FastAPI异步(async/await)到底在什么场景下能真正提升性能。 2. 掌握在FastAPI中正确使用多线程处理CPU密集型任务的方法。 3. 避开常见的坑(比如阻塞操作、数据库连接池耗尽、GIL限制)。 …...

PlayRtttl嵌入式音频引擎:轻量级RTTTL/RTX解析与实时播放

1. PlayRtttl 库深度技术解析:嵌入式平台上的 RTTTL/RTX 音频引擎实现1.1 库定位与工程价值PlayRtttl 是一个面向资源受限嵌入式平台的轻量级 RTTTL(Ring Tone Text Transfer Language)与 RTX(扩展版)音频解析与播放库…...

OpenClaw错误处理机制:Phi-3-vision识别失败自动重试方案

OpenClaw错误处理机制:Phi-3-vision识别失败自动重试方案 1. 为什么需要错误处理机制 上周我在用OpenClaw对接Phi-3-vision模型时,遇到了一个典型问题:当模型识别图片中的文字内容时,偶尔会出现识别失败或结果不准确的情况。这直…...

如何用 MutationObserver 监控第三方插件对 DOM 的篡改

使用MutationObserver监控第三方插件DOM篡改,需精准配置观察选项(childList、subtree、attributes、characterData),聚焦目标容器与可疑变更,安全修复防死循环,并兼顾兼容性与iframe等特殊场景。用 Mutatio…...

红外遥控技术原理与工程实践详解

1. 红外遥控的基本原理红外遥控技术是现代电子设备中最常见的无线控制方式之一。它的核心原理是利用红外光作为信息载体,在发射端和接收端之间建立通信链路。这种看似简单的技术背后,其实蕴含着精妙的物理原理和电子设计。红外光的波长范围通常在700纳米…...

I²C从机块传输驱动:高效实现多字节同步收发

1. 项目概述lib_i2c_slave_block是一个专为嵌入式系统设计的 IC 从机端块传输驱动库,其核心目标是解决标准 HAL 或 LL 库在 IC 从机模式下对连续多字节数据收发支持不足的问题。在实际工业与消费类电子应用中(如传感器集线器、EEPROM 扩展模块、多通道 A…...

龙芯k - 走马观碑组MPU驱动移植孟

先回顾:三次握手(建立连接)核心流程(实际版) 为了让挥手流程衔接更顺畅,咱们先快速回顾三次握手的实际核心,避免上下文脱节: 第一步(客户端→服务器)&#xf…...

F-Theta扫描透镜的性能评估

摘要F-Theta透镜通常用于基于扫描式的激光材料加工系统。使用这种透镜,聚焦光斑沿目标平面的位移与透镜焦距和扫描角度的乘积成正比。然而,不存在完美的F-Theta系统,因此在任何给定的系统中,偏离理想行为的偏差都是可以预期的。借…...

某大型园区服务集团薪酬体系与总额管控优化项目成功案例纪实

——对标市场、分类施策,构建支撑国际化转型的薪酬激励新机制【客户行业】园区服务;物业管理;文旅服务;国有企业【问题类型】薪酬体系改革;薪酬总额管控【客户背景】某大型园区服务集团隶属于某大型央企,位…...

Kiro IDE remote extension host terminated unexpectedly #4231 官方状态:**未修复**(2026最新实测)

【重要】Kiro AI 远程连接崩溃问题 #4231 官方状态:未修复(2026最新实测) 文章目录【重要】Kiro AI 远程连接崩溃问题 #4231 官方状态:**未修复**(2026最新实测)问题描述复现条件官方 Issue 真实状态影响范…...

TechWiz OLED应用:OLED中偏振光源的分析

1. 建模任务 1.1. 模拟条件  光源: EML Emitter (Unit source)  偶极子方向: Polarization  ExEy1/Phase-90˚, 90˚ (circular polarization)  波长: 380~780 nm (10 nm step)  视角: Theta: 0˚~90˚(10˚ step)/ Phi: 0˚~360˚(10˚ step) 1.2 堆栈结构 2.…...

OCAD应用:多重转换式断续变焦系统设计

多组转换型变焦系统可以实现多档断续变焦。设计时同时设计多重可打入活动组,在打入时随意转换。多组转换型的活动组可以放置在会聚光路中也可以在平行光路中。选择在平行光路中,可利用活动组的无焦性来回倒置获得放大缩小两种不同变焦效果。 图1.多组转…...

基于MATLAB/Simulink的纯电动汽车模型( (包括驾驶员模型,电机模型,电池模型,传动模型,纵向动力学模型)

基于MATLAB/Simulink的纯电动汽车模型( (包括驾驶员模型,电机模型,电池模型,传动模型,纵向动力学模型),比较简单,适合零基础或初学者,标准的 Simulink 纯电动…...

Boodskap数字孪生Arduino客户端库深度解析

1. Boodskap IoT Digital Twin Arduino客户端库深度解析Boodskap IoT Digital Twin Arduino Client Library 是一款面向嵌入式边缘设备的轻量级物联网通信中间件,专为将Arduino生态(尤其是ESP32系列)传感器节点快速接入Boodskap Twinned数字孪…...

嵌入式文件传输协议选型与优化实践

1. 嵌入式文件传输协议概述在嵌入式系统开发中,文件传输是设备间数据交换的基础功能。不同于PC环境,嵌入式设备往往受限于资源(内存、CPU、存储)和网络条件(带宽、稳定性),需要专门优化的传输方…...

嵌入式系统开发:硬件思维与架构实践

1. 嵌入式领域的技术特性解析嵌入式系统开发与传统软件工程存在本质差异。在资源受限的硬件环境中,开发者往往需要直接操作寄存器、管理内存分配、处理中断服务例程。这种"贴近金属"的开发方式,决定了嵌入式工程师必须具备硬件思维。以STM32系…...

AI编程实战:从零到一搭建全栈项目胺

1. 核心概念 在 Antigravity 中,技能系统分为两层: Skills (全局库):实际的代码、脚本和指南,存储在系统级目录(如 ~/.gemini/antigravity/skills)。它们是“能力”的本体。 Workflows (项目级)&#xff1a…...

OpenClaw备份恢复方案:Qwen3-32B任务历史与技能配置迁移

OpenClaw备份恢复方案:Qwen3-32B任务历史与技能配置迁移 1. 为什么需要备份OpenClaw工作区 上周我的主力开发机突然硬盘故障,导致整个~/.openclaw目录丢失。当时正在运行的3个自动化流程(日报生成、竞品监控、数据清洗)全部中断…...

金融PHP支付配置终极Checklist(2024Q3央行金融科技新规适配版):58项必检条目,漏1项即触发监管通报

第一章:金融PHP支付配置的监管合规基线定义在金融级PHP支付系统中,监管合规不是可选优化项,而是架构设计的前置约束条件。监管基线定义涵盖数据安全、交易可追溯性、资金隔离、审计留痕及持牌资质映射五大核心维度,其技术实现必须…...

从零构建可审计、可回滚、可监控的向量检索服务:EF Core 10架构设计图+DDD分层实践(含GitHub可运行Demo)

第一章:EF Core 10向量检索服务的核心定位与演进背景EF Core 10首次将原生向量检索能力深度集成至ORM层,标志着.NET数据访问技术从传统关系型查询迈向语义化、多模态检索的新阶段。这一演进并非孤立功能叠加,而是响应大语言模型应用爆发、RAG…...

Linux相关概念和易错知识点(52)(基于System V的信号量和消息队列)

目录1、System V信号量(1)信号量的本质与核心原理(2)PV原语(均为原子操作)a. P原语(申请资源)b. V原语(归还资源)(3)System V信号量接…...

MCP3221 12位I²C ADC驱动设计与精度优化实战

1. MCP3221 12位IC模数转换器底层驱动技术解析MCP3221是Microchip公司推出的超低功耗、单通道、12位分辨率的串行模数转换器(ADC),采用标准IC总线接口,工作电压范围宽达2.7V至5.0V,静态电流典型值仅仅为1.5μA&#xf…...

GraalVM Native Image内存模型深度解构:从Class Initialization Order到Heap Snapshot Graph的7层映射关系图

第一章:GraalVM Native Image内存模型的理论基石与设计哲学GraalVM Native Image 的内存模型并非传统 JVM 堆内存的简单移植,而是基于静态分析与封闭世界假设(Closed World Assumption)重构的全新范式。它在编译期即确定所有可达类…...

GLM技术复盘:篇论文深度解读智谱模型家族菏

开发个什么Skill呢? 通过 Skill,我们可以将某些能力进行模块化封装,从而实现特定的工作流编排、专家领域知识沉淀以及各类工具的集成。 这里我打算来一次“套娃式”的实践:创建一个用于自动生成 Skill 的 Skill,一是用…...

FastAPI子应用挂载:别再让root_path坑你一夜卤

Julia(julialang.org)由Stefan Karpinski、Jeff Bezanson等在2009年创建,目标是融合Python的易用性、C的高性能、R的统计能力、Matlab的科学计算生态。 其核心设计哲学是: 高性能:编译型语言(JIT&#xf…...

AI时代的算法思维:大经典排序学习弥

引言 在现代软件开发中,性能始终是衡量应用质量的重要指标之一。无论是企业级应用、云服务还是桌面程序,性能优化都能显著提升用户体验、降低基础设施成本并增强系统的可扩展性。对于使用 C# 开发的应用程序而言,性能优化涉及多个层面&#x…...

粉紫系超人气月兔铃仙仁

1 安装与初始化 # 全局安装 OpenSpec npm install -g fission-ai/openspeclatest # 在项目目录下初始化 cd /path/to/your-project openspec init 初始化时,OpenSpec 会提示你选择使用的 AI 工具(Claude Code、Cursor、Trae、Qoder 等)。 3 O…...