news 2026/4/19 16:01:08

LeetCode 3010.将数组分成最小总代价的子数组 I:排序 OR 维护最小次小

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LeetCode 3010.将数组分成最小总代价的子数组 I:排序 OR 维护最小次小

【LetMeFly】3010.将数组分成最小总代价的子数组 I:排序 OR 维护最小次小

力扣题目链接:https://leetcode.cn/problems/divide-an-array-into-subarrays-with-minimum-cost-i/

给你一个长度为n的整数数组nums

一个数组的代价是它的第一个元素。比方说,[1,2,3]的代价是1[3,4,1]的代价是3

你需要将nums分成3连续且没有交集的子数组。

请你返回这些子数组的最小代价总和

示例 1:

输入:nums = [1,2,3,12]输出:6解释:最佳分割成 3 个子数组的方案是:[1] ,[2] 和 [3,12] ,总代价为 1 + 2 + 3 = 6 。 其他得到 3 个子数组的方案是: - [1] ,[2,3] 和 [12] ,总代价是 1 + 2 + 12 = 15 。 - [1,2] ,[3] 和 [12] ,总代价是 1 + 3 + 12 = 16 。

示例 2:

输入:nums = [5,4,3]输出:12解释:最佳分割成 3 个子数组的方案是:[5] ,[4] 和 [3] ,总代价为 5 + 4 + 3 = 12 。 12 是所有分割方案里的最小总代价。

示例 3:

输入:nums = [10,3,1,1]输出:12解释:最佳分割成 3 个子数组的方案是:[10,3] ,[1] 和 [1] ,总代价为 10 + 1 + 1 = 12 。 12 是所有分割方案里的最小总代价。

提示:

  • 3 <= n <= 50
  • 1 <= nums[i] <= 50

解题方法:排序 OR 维护最小次小

不难发现,n u m s [ 0 ] nums[0]nums[0]必被第一个子数组选中,后续数组中可以分别将最小值和次小值作为后面两个数组的起始元素。

排序法

n u m s numsnums除第一个元素外的其他部分排序,返回数组前三个元素就好了。

维护最小次小

两个变量m i n 1 min1min1m i n 2 min2min2分别维护除第一个元素外其他部分的最小值和次小值,遍历过程中:

  • 若元素小于等于最小值则令次小值等于最小值,最小值等于该元素
  • 否则,若元素小于次小值,则令次小值等于该元素

时空复杂度分析

  • 时间复杂度:排序O ( n log ⁡ n ) O(n\log n)O(nlogn)、最小次小O ( n ) O(n)O(n)
  • 空间复杂度:排序O ( log ⁡ n ) O(\log n)O(logn)、最小次小O ( 1 ) O(1)O(1)

AC代码

C++ - 排序
/* * @LastEditTime: 2026-02-01 09:51:34 */classSolution{public:intminimumCost(vector<int>&nums){sort(nums.begin()+1,nums.end());returnnums[0]+nums[1]+nums[2];}};
C++ - 最小次小
/* * @LastEditTime: 2026-02-01 09:56:48 */classSolution{public:intminimumCost(vector<int>&nums){intmin1=100,min2=100;for(inti=1;i<nums.size();i++){if(nums[i]<=min1){min2=min1;min1=nums[i];}elseif(nums[i]<min2){min2=nums[i];}}returnnums[0]+min1+min2;}};
Python - 排序一行版
''' LastEditTime: 2026-02-01 10:06:51 '''fromtypingimportListclassSolution:defminimumCost(self,nums:List[int])->int:returnnums[0]+sum(sorted(nums[1:])[:2])

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 11:27:07

WuliArt Qwen-Image Turbo实测:4步生成1024×1024高清图片

WuliArt Qwen-Image Turbo实测&#xff1a;4步生成10241024高清图片 你有没有试过等一张图生成完&#xff0c;咖啡都凉了三次&#xff1f; 有没有在显卡风扇狂转、温度飙升到85℃时&#xff0c;屏幕还卡在「Rendering...」&#xff1f; 有没有明明写了超详细的Prompt&#xff…

作者头像 李华
网站建设 2026/4/16 13:32:36

DamoFD模型性能实测:RTX 3090下200FPS人脸检测实操

DamoFD模型性能实测&#xff1a;RTX 3090下200FPS人脸检测实操 你有没有试过在本地显卡上跑一个人脸检测模型&#xff0c;结果等了十几秒才出框&#xff1f;或者好不容易部署成功&#xff0c;一换图片就报错、崩溃、漏检&#xff1f;别急——这次我们不讲理论&#xff0c;不堆…

作者头像 李华
网站建设 2026/4/16 12:26:29

Qwen3-Reranker-4B快速上手:Gradio WebUI调用+vLLM服务验证全流程

Qwen3-Reranker-4B快速上手&#xff1a;Gradio WebUI调用vLLM服务验证全流程 1. 为什么你需要关注Qwen3-Reranker-4B 你是不是经常遇到这样的问题&#xff1a;搜索结果一大堆&#xff0c;但真正相关的内容总在第5页之后&#xff1f;或者在做RAG应用时&#xff0c;召回的文档质…

作者头像 李华
网站建设 2026/4/18 8:10:33

5分钟部署FSMN-VAD离线语音检测,一键实现音频自动切分

5分钟部署FSMN-VAD离线语音检测&#xff0c;一键实现音频自动切分 你是否遇到过这样的问题&#xff1a;手头有一段30分钟的会议录音&#xff0c;想提取其中所有人说话的片段&#xff0c;但手动听写、标记起止时间要花两小时&#xff1f;或者正在开发语音识别系统&#xff0c;却…

作者头像 李华
网站建设 2026/4/19 2:58:06

用PyTorch-2.x-Universal-Dev-v1.0搭建推荐系统,省下3小时配置时间

用PyTorch-2.x-Universal-Dev-v1.0搭建推荐系统&#xff0c;省下3小时配置时间 你有没有过这样的经历&#xff1a;兴致勃勃想跑一个推荐系统实验&#xff0c;结果卡在环境配置上——CUDA版本不匹配、PyTorch和cuDNN对不上、Jupyter内核死活不识别GPU、pip install半天还在下载…

作者头像 李华