美文网首页
【算法题】2826. 将三个组排序

【算法题】2826. 将三个组排序

作者: 程序员小2 | 来源:发表于2023-08-23 22:00 被阅读0次

题目:

给你一个下标从 0 开始长度为 n 的整数数组 nums 。

从 0 到 n - 1 的数字被分为编号从 1 到 3 的三个组,数字 i 属于组 nums[i] 。注意,有的组可能是 空的 。

你可以执行以下操作任意次:

选择数字 x 并改变它的组。更正式的,你可以将 nums[x] 改为数字 1 到 3 中的任意一个。
你将按照以下过程构建一个新的数组 res :

将每个组中的数字分别排序。
将组 1 ,2 和 3 中的元素 依次 连接以得到 res 。
如果得到的 res 是 非递减顺序的,那么我们称数组 nums 是 美丽数组 。

请你返回将 nums 变为 美丽数组 需要的最少步数。

示例 1:

输入:nums = [2,1,3,2,1]
输出:3
解释:以下三步操作是最优方案:

  1. 将 nums[0] 变为 1 。
  2. 将 nums[2] 变为 1 。
  3. 将 nums[3] 变为 1 。
    执行以上操作后,将每组中的数字排序,组 1 为 [0,1,2,3,4] ,组 2 和组 3 都为空。所以 res 等于 [0,1,2,3,4] ,它是非递减顺序的。
    三步操作是最少需要的步数。
    示例 2:

输入:nums = [1,3,2,1,3,3]
输出:2
解释:以下两步操作是最优方案:

  1. 将 nums[1] 变为 1 。
  2. 将 nums[2] 变为 1 。
    执行以上操作后,将每组中的数字排序,组 1 为 [0,1,2,3] ,组 2 为空,组 3 为 [4,5] 。所以 res 等于 [0,1,2,3,4,5] ,它是非递减顺序的。
    两步操作是最少需要的步数。
    示例 3:

输入:nums = [2,2,2,2,3,3]
输出:0
解释:不需要执行任何操作。
组 1 为空,组 2 为 [0,1,2,3] ,组 3 为 [4,5] 。所以 res 等于 [0,1,2,3,4,5] ,它是非递减顺序的。

提示:

1 <= nums.length <= 100
1 <= nums[i] <= 3

java代码:

class Solution {
    public int minimumOperations(List<Integer> nums) {
        List<Integer> g = new ArrayList<>();
        for (int x : nums) {
            int j = upperBound(g, x);
            if (j == g.size()) g.add(x);
            else g.set(j, x);
        }
        return nums.size() - g.size();
    }

    // 开区间写法
    private int upperBound(List<Integer> g, int target) {
        int left = -1, right = g.size(); // 开区间 (left, right)
        while (left + 1 < right) { // 区间不为空
            // 循环不变量:
            // nums[left] <= target
            // nums[right] > target
            int mid = (left + right) >>> 1;
            if (g.get(mid) <= target)
                left = mid; // 范围缩小到 (mid, right)
            else
                right = mid; // 范围缩小到 (left, mid)
        }
        return right; // 或者 left+1
    }
}


相关文章

  • 排序算法介绍和分类

    排序算法的介绍 排序也称排序算法(Sort Alogorithm),排序是将一组数据,依指定的顺序进行排序的过程 ...

  • 数据结构之排序算法

    1.排序算法介绍 排序也称排序算法�(Sort Algorithm),排序是将一�组数据,依指定的顺序进行排列�的...

  • 编程马拉松 Day04 希尔排序、归并排序、快速排序

    本文将介绍三个高级排序算法 希尔排序 归并排序 快速排序 希尔排序 希尔排序(Shell's Sort)的名称源于...

  • 面试必备:高频算法题汇总「图文解析 + 教学视频 + 范例代码」

    排序 所谓排序算法,即通过特定的算法因式将一组或多组数据按照既定模式进行重新排序。这种新序列遵循着一定的规则,体现...

  • Java数据结构与算法:排序算法

    一、基本介绍 排序也称排序算法(Sort Algorithm),排序是将一组数据,依指定的顺序进行排列的过程。 排...

  • 冒泡排序算法

    1.什么是冒泡排序算法? 将一组元素两两相比较,直至该组元素顺序为由小到大。 2.冒泡排序算法原理: (1)从首位...

  • 排序的复习(上篇)

    ### 排序算法概述 排序就是将一组对象按照某种逻辑顺序重新排列的过程。比如,订单按照日期排序的——这种排序很可能...

  • 排序算法

    排序就是将一组对象按照某种逻辑顺序重新排列的过程。 排序有十大算法:包括冒泡排序,简单选择排序,简单插入排序,归并...

  • 排序算法总括-java版

    什么是排序算法 排序算法,顾名思义,就是对一组数据进行排序的算法,可以按照升序也可以按照降序 排序算法的分类 从大...

  • 排序算法基础

    1、概念 所谓排序算法,即通过特定的算法因式将一组或多组数据按照既定模式进行重新排序。这种新序列遵循着一定的规则,...

网友评论

      本文标题:【算法题】2826. 将三个组排序

      本文链接:https://www.haomeiwen.com/subject/zdfmmdtx.html