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

day24-数据结构力扣

122.买卖股票的最佳时机II题目链接122. 买卖股票的最佳时机 II - 力扣LeetCode思路这个题感觉和之前一个题有点像就是摆动序列但是又有点不太一样本题的核心规则可以无限次买卖任何时候最多持有 1 股同一天可以买了再卖求最大利润只要后一天价格 前一天价格就把这两天的差价赚到手。所有上涨日的差价加起来 最大利润。为什么正确连续上涨1→2→3→4→5每天赚差价(2-1)(3-2)(4-3)(5-4) 5-1和一次买卖结果完全一样两个题的区别股票题只赚涨的钱跌的不碰摆动序列交替涨跌都算统计最长长度提交很神奇我以为会是很复杂的手段结果和我想的不一样有一种四两拨千斤的感觉仿佛大脑的褶皱被抚平class Solution: def maxProfit(self, prices: List[int]) - int: profit 0 # 从第2天开始遍历 for i in range(1, len(prices)): # 只要今天比昨天贵就赚差价 if prices[i] prices[i-1]: profit prices[i] - prices[i-1] return profit55. 跳跃游戏题目链接55. 跳跃游戏 - 力扣LeetCode思路首先我没看懂题的意思又开始阅读理解了规则数组nums[i]在位置i最多能跳几步起点下标0目标判断能不能到达最后一个下标示例 1 输入nums [2,3,1,1,4]输出true 解释可以先跳 1 步从下标 0 到达下标 1, 然后再从下标 1 跳 3 步到达最后一个下标。我懂了每个数组位置数字是最多能跳几步核心思想用一个变量max_reach记录当前能跳到的最远位置遍历数组每到一个位置就更新最远能跳到哪如果遍历的位置超过了最远可达位置说明卡住了直接返回false如果最远位置 最后一个下标直接返回true一句话只要当前位置还能跳到就不断更新最远跳跃距离。提交class Solution: def canJump(self, nums: List[int]) - bool: max_reach 0 # 记录当前能跳到的最远下标 n len(nums) for i in range(n): # 如果当前位置都跳不到直接失败 if i max_reach: return False # 更新最远能跳到的位置 max_reach max(max_reach, i nums[i]) # 已经能跳到终点提前返回 if max_reach n - 1: return True return True45.跳跃游戏II题目链接45. 跳跃游戏 II - 力扣LeetCode思路这简直就是55跳跃游戏的plus版本核心逻辑不关心每一步具体跳到哪个位置只关心当前能到达的最远位置当遍历到当前跳跃的边界时必须进行一次跳跃同时更新边界为新的最远位置。三个关键变量jumps记录最小跳跃次数最终结果current_end当前这一步能到达的最远边界farthest遍历过程中能到达的全局最远位置遍历规则遍历数组不需要遍历最后一个元素因为到了最后一个元素就已经到达终点每遍历一个位置更新能到达的最远位置farthest当遍历到current_end时说明必须跳一步jumps1并把current_end更新为farthest以nums [2,3,1,1,4]为例初始jumps0, current_end0, farthest0i0farthest max(0, 02) 2i current_end→jumps1current_end2i1farthest max(2, 13) 4i2farthest max(4, 21) 4i current_end→jumps2current_end4已经到达终点退出最终返回2提交class Solution: def jump(self, nums: List[int]) - int: n len(nums) jumps 0 # 记录跳跃次数 current_end 0 # 当前跳跃的边界 farthest 0 # 能到达的最远位置 # 不需要遍历最后一个元素因为已经到达终点 for i in range(n - 1): # 更新最远能到达的位置 farthest max(farthest, i nums[i]) # 到达当前边界必须跳一次 if i current_end: jumps 1 current_end farthest # 优化如果已经能跳到终点直接提前退出 if current_end n - 1: break return jumps1005.K次取反后最大化的数组和题目链接1005. K 次取反后最大化的数组和 - 力扣LeetCode思路依旧还是先做阅读理解k是指可以选择k个数字将他们的正负号反转但是具体反转那个不知道。有不同的反转方案我们要得到最佳方案就是这些方法里面数组之和最大的那个结果第一版思路通过66/84可以先把数组排序我们反转数组里面较小的数字对于正数反转之后减的最少那就是反最小的正数对于负数反转之后加的最大反负更多的也就是更小的负数比如【4,2,3】k1排序【2,3,4】就是反转2【2-3-15-4】k2排序【-4-3-1,2,5】反转-4-3但是有一种特殊情况 就是有0的因为题目说有些下标是可以多次反转的那我们把负的反过来之后还有次数就反转0这里正数部分应该单独处理比如把正数反转之后我们应该找修改数组后的最小值反转而不是继续遍历反转提交from typing import List class Solution: def largestSumAfterKNegations(self, nums: List[int], k: int) - int: # 从小到大排序优先翻转最小的负数收益最大 nums.sort() for i in range(len(nums)): if nums[i]0: # 翻转当前最小负数为正数消耗一次翻转次数 nums[i] -nums[i] k - 1 if k 0: # 翻转次数用完直接退出 break elif nums[i]0: # 遇到0剩余次数全部翻转0总和不变 k 0 break else: # 后面全是正数无需继续翻转 break if k0 and k%21: # 剩余奇数次翻转必须翻转一次最小值损失最小 nummin(nums) indexnums.index(num) nums[index]-nums[index] return sum(nums)

相关文章:

day24-数据结构力扣

122.买卖股票的最佳时机II 题目链接122. 买卖股票的最佳时机 II - 力扣(LeetCode) 思路 这个题感觉和之前一个题有点像,就是摆动序列,但是又有点不太一样 本题的核心规则: 可以无限次买卖 任何时候最多持有 1 股…...

macOS窗口管理终极指南:用Topit一键置顶解决多窗口混乱难题

macOS窗口管理终极指南:用Topit一键置顶解决多窗口混乱难题 【免费下载链接】Topit Pin any window to the top of your screen / 在Mac上将你的任何窗口强制置顶 项目地址: https://gitcode.com/gh_mirrors/to/Topit 你是否曾在工作中被多个重叠的窗口搞得焦…...

如何快速解密RPG游戏资源:5分钟掌握RPG Maker加密文件提取技巧

如何快速解密RPG游戏资源:5分钟掌握RPG Maker加密文件提取技巧 【免费下载链接】RPG-Maker-MV-Decrypter You can decrypt RPG-Maker-MV Resource Files with this project ~ If you dont wanna download it, you can use the Script on my HP: 项目地址: https:/…...

Python实战:全球植被生产力BEPS模型数据(1981-2019)的读取、转换与可视化分析

1. 认识BEPS模型数据 全球植被生产力数据是研究生态系统碳循环的重要基础。居为民教授团队发布的1981-2019年全球逐日GPP/NEP/NPP数据集,采用BEPS(Boreal Ecosystem Productivity Simulator)模型生成,这个模型考虑了植被参数、气象…...

思源宋体TTF:免费商用中文字体的完美解决方案

思源宋体TTF:免费商用中文字体的完美解决方案 【免费下载链接】source-han-serif-ttf Source Han Serif TTF 项目地址: https://gitcode.com/gh_mirrors/so/source-han-serif-ttf 还在为商业项目寻找高质量、免费可商用的中文字体而烦恼吗?今天让…...

Linux CFS 的 switched_from/switched_to:调度类切换的处理

一、简介在Linux内核的调度子系统中,任务在不同调度类之间切换是一个复杂且关键的操作。当应用程序调用sched_setscheduler()将任务从普通调度策略(SCHED_NORMAL)切换为实时策略(SCHED_FIFO/SCHED_RR),或者…...

从Word2Vec到Attention:用‘讲故事’的方式,轻松理解NLP核心模型演进史

从Word2Vec到Attention:用故事串联NLP模型演进之路 想象一下,你正在教一个刚学会认字的孩子理解"国王-男人女人≈女王"这样的词语关系。这看似简单的语言游戏背后,隐藏着自然语言处理(NLP)技术数十年的智慧结晶。让我们穿越时空&am…...

Windows 11任务栏拖放修复:让消失的拖拽功能重获新生

Windows 11任务栏拖放修复:让消失的拖拽功能重获新生 【免费下载链接】Windows11DragAndDropToTaskbarFix "Windows 11 Drag & Drop to the Taskbar (Fix)" fixes the missing "Drag & Drop to the Taskbar" support in Windows 11. It…...

别再手动删注册表了!一个PowerShell脚本搞定eNSP安装时的WinPcap 4.1.3报错

告别手动清理:用PowerShell自动化解决eNSP与WinPcap的版本冲突 当网络工程师在Windows系统上安装华为eNSP模拟器时,WinPcap 4.1.3的安装报错堪称经典难题。传统解决方案往往要求用户手动操作注册表、系统目录和服务管理器——这种繁琐过程不仅效率低下&a…...

SRE面试必问:K8s生产环境故障排查实战案例解析(附避坑指南)

SRE面试必问:K8s生产环境故障排查实战案例解析(附避坑指南) 在当今云原生技术蓬勃发展的时代,Kubernetes(K8s)已成为企业级容器编排的事实标准。作为Site Reliability Engineer(SRE)…...

RK3588开发板Android系统多屏显示方向动态调整实战

1. RK3588开发板多屏显示基础认知 第一次拿到RK3588开发板时,最让我惊艳的就是它强大的多屏显示能力。这块板子不仅能同时驱动MIPI、HDMI、DP等多种接口的显示屏,还能让每个屏幕独立设置显示方向。在实际项目中,这种特性特别适合数字标牌、互…...

GIS小白必看:如何用GeoServer把普通图片变成可交互地图(附QGIS配准技巧)

GIS入门实战:从普通图片到可交互地图的完整指南 引言:为什么需要将图片转换为可交互地图? 在日常工作中,我们经常会遇到这样的场景:客户提供了一张手绘地图、历史航拍图或是扫描的规划图纸,但这些图片文件…...

CLIP-GmP-ViT-L-14图文匹配工具效果展示:多物体复杂场景中‘主对象’优先匹配

CLIP-GmP-ViT-L-14图文匹配工具效果展示:多物体复杂场景中‘主对象’优先匹配 你有没有遇到过这种情况?一张照片里,有猫、有狗、有沙发、有地毯,背景还有窗外的树。当你问一个AI模型“这张图里有什么”时,它可能会告诉…...

Bilibili-Old:重温经典界面,找回最初的B站体验

Bilibili-Old:重温经典界面,找回最初的B站体验 【免费下载链接】Bilibili-Old 恢复旧版Bilibili页面,为了那些念旧的人。 项目地址: https://gitcode.com/gh_mirrors/bi/Bilibili-Old 你是否怀念那个简洁明了的B站界面?是否…...

在DEBUG环境通过AX、BX 寄存器操作命令理解ALU、ACC的运算逻辑

DEBUG环境下 AX、BX 寄存器操作命令(完整版)12 在DEBUG环境通过AX、BX 寄存器操作命令理解ALU、ACC的运算逻辑 说明:DEBUG是DOS系统下的调试工具,可直接操作CPU内部寄存器(含AX、BX),以下命令…...

告别printf调试!用Telink EVK实时监控BLE芯片变量(8258/8255实战示例)

告别printf调试!用Telink EVK实时监控BLE芯片变量(8258/8255实战示例) 调试嵌入式系统时,开发者常陷入两难:既需要观察程序运行时的内部状态,又受限于传统调试方法的低效。在BLE低功耗场景下,这…...

5步掌握个人数据主权:从微信聊天到AI记忆的完整指南

5步掌握个人数据主权:从微信聊天到AI记忆的完整指南 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we/WeChatM…...

告别SysML v1的混乱:手把手教你用M-Design v2搞定柴油发动机功能分解(Action Usage实战)

从SysML v1到v2的工程革命:柴油发动机功能分解的M-Design v2实践指南 当系统工程师第一次打开SysML v2的规范文档时,那种感觉就像从DOS命令行突然跳进了图形化操作系统时代。作为在汽车行业深耕十余年的系统架构师,我见证过太多团队在SysML v…...

保姆级避坑指南:用ESP-IDF v5.0给虫洞ESP32S3-EYE编译UVC固件,解决屏幕不亮和下载失败

ESP32-S3 UVC摄像头开发实战:从固件编译到屏幕显示的深度排错指南 当你第一次拿到那块印着"ESP32-S3-EYE"的开发板时,脑海中可能已经浮现出无数创意项目——智能门铃、工业检测设备、甚至是一个DIY的视频会议终端。但现实往往比理想骨感得多&a…...

【LabVIEW FPGA图形化】 跨越工具链:在Spartan-6上集成Vivado edf网表的实战解析

1. 当Spartan-6遇上Vivado:工具链冲突的破局之道 遇到Xilinx Spartan-6这类经典FPGA型号时,很多工程师都会头疼一个问题:它只能用老旧的ISE工具链开发,而手头现成的Vivado工程生成的edf网表文件直接导入会报错。去年我在做工业控…...

旅游安全监控:紧急求助与位置追踪的系统

旅游安全监控:紧急求助与位置追踪的系统 随着旅游业的蓬勃发展,游客的安全问题日益受到关注。无论是独自探险的背包客,还是家庭出游的亲子团,都可能面临迷路、突发疾病或意外事故等风险。为此,旅游安全监控系统应运而…...

126. 如何为 Elemental OS Machine 创建网络绑定

Procedure 程序Configuring NIC Teaming for OS Elemental 为操作系统 Elemental 配置 NIC 分组 Overview 概述 This article provides the procedure for configuring NIC Teaming (bonding) in SUSE Elemental OS. It includes an example configuration that can be adjus…...

Mermaid Live Editor终极指南:实时图表编辑与可视化工具深度解析

Mermaid Live Editor终极指南:实时图表编辑与可视化工具深度解析 【免费下载链接】mermaid-live-editor Edit, preview and share mermaid charts/diagrams. New implementation of the live editor. 项目地址: https://gitcode.com/GitHub_Trending/me/mermaid-l…...

邻架控制器4C型护套连接器BMJDDL conm/12c(4000)

在煤矿综采工作面液压支架电液控制系统中,邻架控制器之间的级联通信是实现支架群组协同动作的关键。BMJDDL conm/12c(4000) 是一款专为邻架通信设计的12芯钢丝编织橡胶护套连接器,其长度4000mm(4米)适配液压支架的标准中心距&…...

ncmdump终极指南:3步解锁网易云音乐NCM格式,实现音乐自由播放

ncmdump终极指南:3步解锁网易云音乐NCM格式,实现音乐自由播放 【免费下载链接】ncmdump 项目地址: https://gitcode.com/gh_mirrors/ncmd/ncmdump 你是否曾在网易云音乐下载了心爱的歌曲,却发现在车载音响、其他播放器或设备上无法播…...

语音转文字还在手动操作?3分钟学会AsrTools的完整解决方案

语音转文字还在手动操作?3分钟学会AsrTools的完整解决方案 【免费下载链接】AsrTools ✨ AsrTools: Smart Voice-to-Text Tool | Efficient Batch Processing | User-Friendly Interface | No GPU Required | Supports SRT/TXT Output | Turn your audio into accur…...

如何让微信聊天记录成为你的数字记忆银行?WeChatMsg终极指南

如何让微信聊天记录成为你的数字记忆银行?WeChatMsg终极指南 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we…...

不止于蓝牙!挖掘杰理AC632N的隐藏技能:SPP/LE与CDC双模通信实战,一个设备搞定所有调试

杰理AC632N双模通信实战:SPP/LE与CDC的协同设计艺术 当一块开发板能同时完成蓝牙数据透传和有线调试,你会用它做什么?杰理AC632N这颗国产芯片的潜力远超多数开发者的想象。今天我们不谈基础功能,而是聚焦一个真实开发场景&#x…...

别急着升Unity 2022!手把手教你为Unity 2021.3项目配置专属的Java 11和Gradle 7.5环境

深度定制Unity 2021.3的Android构建环境:Java 11与Gradle 7.5实战指南 当Google Play强制要求应用适配Android 14(API Level 34)时,许多仍在使用Unity 2021.3 LTS的开发者面临一个棘手问题:如何在不升级Unity版本的前…...

React Fiber 优先级队列实现

React Fiber优先级队列实现解析 React Fiber是React 16引入的核心架构,旨在优化渲染性能并支持任务优先级调度。其中,优先级队列的实现是关键机制之一,它确保高优先级任务(如用户交互)能快速响应,而低优先…...