leetcode 3010

3010: 将数组分成最小总代价的子数组Ⅰ

题意:把数组分成三段,每一段取第一个数求和,问和的最小值是多少。

第一段的第一个数是确定的,即 nums[0]。

如果知道了第二段的第一个数的位置,和第三段的第一个数的位置,那么这个划分方案也就确定了。这两个下标可以在 [1,n−1] 中随意取。

所以问题变成求下标在 [1,n−1] 中的两个最小的数。

复制代码
class Solution {
public:
    int minimumCost(vector<int>& nums) {
        sort(nums.begin()+1,nums.end());
        int ans=nums[0]+nums[1]+nums[2];
        return ans;
    }
};
相关推荐
落羽的落羽39 分钟前
【算法札记】练习 | Week4
linux·服务器·数据结构·c++·人工智能·算法·动态规划
萑澈1 小时前
算法竞赛入门:C++ STL核心用法与时空复杂度速查手册
数据结构·c++·算法·stl
Godspeed Zhao2 小时前
从零开始学AI16——SVM
算法·机器学习·支持向量机
江屿风2 小时前
C++OJ题经验总结(竞赛)1
开发语言·c++·笔记·算法
nebula-AI2 小时前
人工智能导论:模型与算法(核心技术)
人工智能·深度学习·神经网络·算法·机器学习·集成学习·sklearn
运筹vivo@2 小时前
LeetCode 2405. 子字符串的最优划分
c++·算法·leetcode·职场和发展·哈希表
数智工坊2 小时前
视觉-语言-动作模型解剖学:从模块、里程碑到核心挑战
论文阅读·人工智能·深度学习·算法·transformer
yuannl103 小时前
数据结构----二叉排序树(ai修改版)
数据结构
有点。3 小时前
C++(枚举法一练习题)
开发语言·c++·算法