【LeetCode 每日一题】3010. 将数组分成最小总代价的子数组 I——(解法二)排序

Problem: 3010. 将数组分成最小总代价的子数组 I

文章目录

  • [1. 整体思路](#1. 整体思路)
  • [2. 完整代码](#2. 完整代码)
  • [3. 时空复杂度](#3. 时空复杂度)
      • [时间复杂度: O ( N log ⁡ N ) O(N \log N) O(NlogN)](#时间复杂度: O ( N log ⁡ N ) O(N \log N) O(NlogN))
      • [空间复杂度: O ( log ⁡ N ) O(\log N) O(logN)](#空间复杂度: O ( log ⁡ N ) O(\log N) O(logN))

1. 整体思路

核心问题

我们需要将数组 nums 分成 3 个连续子数组,总代价是这 3 个子数组首元素的和。

算法逻辑

  1. 必选元素 :第一个子数组必须以 nums[0] 开头,因此 nums[0] 必定计入总代价。
  2. 贪心选择 :为了使总代价最小,剩下的两个子数组的头元素必须是 nums 剩余部分(即索引 1 到结尾)中最小的两个数
  3. 局部排序
    • 我们不需要对整个数组排序(因为 nums[0] 的位置不能动)。
    • 我们只需要对 nums 从索引 1 开始的后缀进行排序。
    • Java 的 Arrays.sort(array, fromIndex, toIndex) 方法允许我们只对指定范围进行排序。
  4. 计算结果 :排序后,剩余部分的最小值变成了 nums[1],第二小变成了 nums[2]。结果即为 nums[0] + nums[1] + nums[2]

2. 完整代码

java 复制代码
import java.util.Arrays;

class Solution {
    public int minimumCost(int[] nums) {
        // 1. 局部排序
        // Arrays.sort(array, fromIndex, toIndex) 对数组的特定范围进行排序
        // fromIndex (包括): 1
        // toIndex (不包括): nums.length
        // 这一步操作后,nums[0] 保持原位不动,而 nums[1] 到最后的部分变成了升序排列
        Arrays.sort(nums, 1, nums.length);
        
        // 2. 计算最小代价
        // nums[0]: 原数组的第一个元素 (固定必选)
        // nums[1]: 剩下所有元素中的最小值
        // nums[2]: 剩下所有元素中的第二小值
        return nums[0] + nums[1] + nums[2];
    }
}

3. 时空复杂度

假设数组 nums 的长度为 N N N。

时间复杂度: O ( N log ⁡ N ) O(N \log N) O(NlogN)

  • 计算依据
    • 代码核心是对长度为 N − 1 N-1 N−1 的子区间进行排序。
    • Arrays.sort 对于基本数据类型使用的是双轴快速排序(Dual-Pivot Quicksort),平均时间复杂度为 O ( N log ⁡ N ) O(N \log N) O(NlogN)。
  • 结论 : O ( N log ⁡ N ) O(N \log N) O(NlogN)。

空间复杂度: O ( log ⁡ N ) O(\log N) O(logN)

  • 计算依据
    • 相比上一版,这里没有使用 Arrays.copyOfRange 创建新数组,节省了 O ( N ) O(N) O(N) 的堆空间。
    • 但是,快速排序是递归实现的,需要消耗栈空间来存储递归调用的上下文。栈深度为 O ( log ⁡ N ) O(\log N) O(logN)。
  • 结论 : O ( log ⁡ N ) O(\log N) O(logN)。
相关推荐
汀、人工智能5 小时前
[特殊字符] 第21课:最长有效括号
数据结构·算法·数据库架构·图论·bfs·最长有效括号
Boop_wu6 小时前
[Java 算法] 字符串
linux·运维·服务器·数据结构·算法·leetcode
故事和你916 小时前
洛谷-算法1-2-排序2
开发语言·数据结构·c++·算法·动态规划·图论
Fcy6487 小时前
算法基础详解(三)前缀和与差分算法
算法·前缀和·差分
kvo7f2JTy7 小时前
基于机器学习算法的web入侵检测系统设计与实现
前端·算法·机器学习
List<String> error_P7 小时前
蓝桥杯最后几天冲刺:暴力大法(一)
算法·职场和发展·蓝桥杯
流云鹤8 小时前
Codeforces Round 1090 (Div. 4)
c++·算法
wljy18 小时前
第十三届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组(个人见解,已完结)
c语言·c++·算法·蓝桥杯·stl
清空mega9 小时前
C++中关于数学的一些语法回忆(2)
开发语言·c++·算法
香蕉鼠片10 小时前
数据结构八股(一)
数据结构·算法