leetcode2826.将三个组排序

java 复制代码
class Solution {
    public int minimumOperations(List<Integer> nums) {
        int[][] dp = new int[nums.size()][3 + 1];
        dp[0][nums.get(0)]=1;
        for (int i = 1; i < nums.size(); i++) {
            dp[i][1]=dp[i-1][1];
            dp[i][2]=dp[i-1][2];
            dp[i][3]=dp[i-1][3];
            switch (nums.get(i)){
                case 1 -> dp[i][1] = Math.max(dp[i - 1][1] + 1, dp[i - 1][0] + 1);
                case 2 -> dp[i][2] = Math.max(dp[i - 1][2] + 1, dp[i - 1][1] + 1);
                case 3-> dp[i][3] = Math.max(dp[i - 1][3] + 1, Math.max(dp[i - 1][2] + 1, dp[i - 1][1] + 1));
            }
        }
        int n = nums.size();
        return n - Math.max(dp[n - 1][1], Math.max(dp[n - 1][2], dp[n - 1][3]));
    }
}

优化版本

java 复制代码
class Solution {
    public int minimumOperations(List<Integer> nums) {
        //1.定义状态
        int _1 = 0, _2 = 0, _3 = 0;//分别表示以1、2、3结尾的子序列长度
        //2.状态转移
        for (int num : nums) {
            switch (num){
                case 1-> _1 = Math.max(_1 + 1, 1);
                case 2-> _2 = Math.max(_2 + 1, _1 + 1);
                case 3-> _3 = Math.max(_3 + 1, Math.max(_2 + 1, _1 + 1));
            }
        }
        //3.返回结果
        return nums.size() - Math.max(_1, Math.max(_2, _3));
    }
}
相关推荐
JieE2121 天前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2122 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack202 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树3 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2123 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2123 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术3 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦3 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050734 天前
(一)小红的数组操作
算法·编程语言