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));
    }
}
相关推荐
智者知已应修善业5 小时前
【51单片机单按键切换广告屏】2023-5-17
c++·经验分享·笔记·算法·51单片机
广州灵眸科技有限公司5 小时前
为RK3588注入澎湃算力:RK1820 AI加速卡完整适配与评测指南
linux·网络·人工智能·物联网·算法
qinian_ztc5 小时前
frida 14.2.18 安装报错解决
算法·leetcode·职场和发展
AI应用实战 | RE5 小时前
012、检索器(Retrievers)核心:从向量库中智能查找信息
人工智能·算法·机器学习·langchain
凤年徐5 小时前
C++手撕红黑树:从0到200行,拿下STL map底层核心
c++·后端·算法
Thomas.Sir5 小时前
AI 医疗之罕见病/疑难病辅助诊断系统从算法到实现【表型驱动与知识图谱推理】
人工智能·算法·ai·知识图谱
tankeven6 小时前
动态规划专题(03):区间动态规划从原理到实践(未完待续)
c++·算法·动态规划
田梓燊7 小时前
2026/4/11 leetcode 3741
数据结构·算法·leetcode
斯内科7 小时前
FFT快速傅里叶变换
算法·fft
2301_822703207 小时前
开源鸿蒙跨平台Flutter开发:幼儿疫苗全生命周期追踪系统:基于 Flutter 的免疫接种档案与状态机设计
算法·flutter·华为·开源·harmonyos·鸿蒙