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

【灵神题单·贪心】3010. 将数组分成最小总代价的子数组 I | Java

🔗 题目链接:3010. 将数组分成最小总代价的子数组 I
📚 所属题单:灵茶山艾府 · 贪心算法题单 — §1.1 从最小/最大开始贪心
🏷️ 难度:Easy | 难度分:1292
🔖 标签:贪心、数组

📖 题目描述

把长度为 n 的整数数组nums分成3 个连续子数组。每个子数组的代价 = 第一个元素,返回最小代价总和。

示例 1

输入:nums = [1,2,3,12] 输出:6 解释:[1], [2], [3,12],代价 1+2+3=6

示例 2

输入:nums = [10,3,1,1] 输出:12 解释:[10,3], [1], [1],代价 10+1+1=12

💡 思路分析

第一个子数组一定从nums[0]开始,代价固定为nums[0]

另外两个子数组各自的代价是它们的第一个元素——而这两个"分割点"可以是nums[1:]中的任意两个位置。所以问题等价于:在 nums[1:] 中找最小的两个数

一次遍历,维护最小和次小值就够了 🎯

✅ 代码实现(Java)

classSolution{publicintminimumCost(int[]nums){intfirst=Integer.MAX_VALUE,second=Integer.MAX_VALUE;for(inti=1;i<nums.length;i++){if(nums[i]<first){second=first;first=nums[i];}elseif(nums[i]<second){second=nums[i];}}returnnums[0]+first+second;}}

📊 复杂度分析

复杂度说明
⏱️ 时间O(n)一次遍历
💾 空间O(1)常数空间

🔗 参考

  • 灵茶山艾府 · 贪心算法题单

🎯 这题的关键洞察:分割点的代价就是那个位置的元素值,所以最优解就是找 nums[1:] 中最小的两个数。O(n) 一遍搞定,击败 99.91%!

http://www.jsqmd.com/news/524313/

相关文章:

  • 成都施工吊篮租赁优选指南适配多场景需求:成都工地吊篮租赁/成都建筑吊篮租赁/成都施工吊篮租赁/成都电动吊篮租赁/选择指南 - 优质品牌商家
  • CSS3文字闪烁效果实战:3种方法让你的网页标题更吸睛(附完整代码)
  • 汇编指令机器码速查手册:从MOV到JMP,一网打尽(附PDF下载)
  • 豆包推广效果怎么样?如何联系专业豆包AI广告服务商? - 品牌2026
  • 突破网页复制限制:三种实用方法助你轻松获取文字与图片(第三种方法最便捷)
  • 2026手游联运平台系统推荐榜:H5联运平台系统、手游平台sdk、手游平台源码、手游平台系统、手游联运平台系统选择指南 - 优质品牌商家
  • 大厂千万级数据量 Redis 缓存该如何设计?学费了
  • WannaCry勒索病毒传播机制深度剖析:从漏洞利用到蠕虫扩散的全链路解析 | 技术实战
  • 20252910 2025-2026-2《网络攻防实践》第二周作业
  • 3.22 OJ
  • 威联通NAS iSCSI实战:如何将NAS硬盘变成电脑的‘第二块硬盘’(附速度测试对比)
  • 20243409 实验一《Python程序设计》实验报告
  • 大模型微调——Fine-tuning
  • 别再死记硬背了!SolidWorks二次开发,用好APIHelp这个“活字典”就够了
  • 在Java中如何理解方法访问修饰符的作用
  • 金仓数据库性能调优全攻略:从基础查询到高并发场景优化(附电子证照系统案例)
  • 20253214庄景博 实验1报告
  • egoShieldTimeLapse:基于STM32的延时摄影运动控制库
  • 豆包AI推广效果怎么?2026企业获客实效深度评测 - 品牌2026
  • [INFRA] EMR集群LogPusher组件功能和运行原理分析
  • AtCoder Beginner Contest 450 复盘
  • YYQ-16A圈带动平衡机
  • MATLAB/Simulink 两相交错并联Buck电路仿真:电压闭环控制之旅
  • 2026最新国内防护眼镜推荐!外贸出口优质防护眼镜权威榜单发布 - 十大品牌榜
  • 编译原理课程设计
  • 【路径规划】在二维和三维空间中实现RRT_算法,根据障碍物位置和尺寸实现的避障功能附matlab代码
  • 【SAP PO】从零开始:SAP PO与RFC接口的WebServices服务实战指南
  • 20243408 2025-2026-2 《Python程序设计》实验1报告
  • 20252411 实验一《Python程序设计》实验报告
  • 实战分享:用roslibjs在Web端控制机器人移动(附完整代码示例)