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;
    }
};
相关推荐
Anastasiozzzz2 小时前
MySQL JOIN:底层原理、算法演进与多表性能之谜
算法
元亓亓亓2 小时前
考研408--数据结构--day15--排序&内部排序(上)
数据结构·408·排序·内部排序
追随者永远是胜利者8 小时前
(LeetCode-Hot100)253. 会议室 II
java·算法·leetcode·go
Jason_Honey28 小时前
【平安Agent算法岗面试-二面】
人工智能·算法·面试
程序员酥皮蛋8 小时前
hot 100 第三十五题 35.二叉树的中序遍历
数据结构·算法·leetcode
追随者永远是胜利者9 小时前
(LeetCode-Hot100)207. 课程表
java·算法·leetcode·go
仰泳的熊猫9 小时前
题目1535:蓝桥杯算法提高VIP-最小乘积(提高型)
数据结构·c++·算法·蓝桥杯
那起舞的日子10 小时前
动态规划-Dynamic Programing-DP
算法·动态规划
闻缺陷则喜何志丹10 小时前
【前后缀分解】P9255 [PA 2022] Podwyżki|普及+
数据结构·c++·算法·前后缀分解
每天吃饭的羊10 小时前
时间复杂度
数据结构·算法·排序算法