LeetCode 训练场:1051. 高度检查器

简介: LeetCode 训练场:1051. 高度检查器

1. 题目

1051. 高度检查器


2. 描述

学校在拍年度纪念照时,一般要求学生按照 非递减 的高度顺序排列。


请你返回能让所有学生以 非递减 高度排列的最小必要移动人数。


注意,当一组学生被选中时,他们之间可以以任何可能的方式重新排序,而未被选中的学生应该保持不动。


示例:


输入: heights = [1,1,4,2,1,3]


输出: 3


解释:


当前数组:[1,1,4,2,1,3]


目标数组:[1,1,1,2,3,4]


在下标 2 处(从 0 开始计数)出现 4 vs 1 ,所以我们必须移动这名学生。


在下标 4 处(从 0 开始计数)出现 1 vs 3 ,所以我们必须移动这名学生。


在下标 5 处(从 0 开始计数)出现 3 vs 4 ,所以我们必须移动这名学生。


示例 2:


输入: heights = [5,1,2,3,4]


输出: 5


示例 3:


输入: heights = [1,2,3,4,5]


输出: 0


3. 思路

仔细分析其实可以发现,如果我们将原数组进行排序后,然后将排序后的数组与原数组进行对比,其中索引位置相同但元素不同的个数即为需要移动的次数。此时主要进行的排序(O ( n l o g n ) O(nlogn)O(nlogn))和遍历操作(O ( n ) O(n)O(n)),所以最终的时间复杂度为 O ( n l o g n ) O(nlogn)O(nlogn).


4. 实现


public int heightChecker(int[] heights) {
    // 将原数组复制到一个新数组中
    int[] result = new int[heights.length];
    for(int i = 0; i < heights.length; i++){
        result[i] = heights[i];
    }
    // 计数
    int count = 0;
    // 新数组排序
    Arrays.sort(result);
    // 对比排序后的新数组和原数组,其中对应索引位置不同的元素个数即为最终结果
    for(int i = 0; i < heights.length; i++){
        if(result[i] != heights[i]){
            count++;
        }
    }
    return count;
}
目录
相关文章
|
6月前
|
机器学习/深度学习
力扣2596. 检查骑士巡视方案
力扣2596. 检查骑士巡视方案
|
6月前
leetcode-1784:检查二进制字符串字段
leetcode-1784:检查二进制字符串字段
34 0
|
算法
每日算法系列【LeetCode 1250】检查「好数组」
每日算法系列【LeetCode 1250】检查「好数组」
Leetcode-每日一题1250. 检查「好数组」(裴蜀定理)
版权声明:本文为博主原创文章,未经博主允许不得转载。https://blog.csdn.net/weixin_46618592/article/details/129038912?spm=1001.2014.3001.5502
127 0
Leetcode-每日一题1250. 检查「好数组」(裴蜀定理)
|
Python
LeetCode 1941. 检查是否所有字符出现次数相同
给你一个字符串 s ,如果 s 是一个 好 字符串,请你返回 true ,否则请返回 false 。
101 0
LeetCode 1662. 检查两个字符串数组是否相等
给你两个字符串数组 word1 和 word2 。如果两个数组表示的字符串相同,返回 true ;否则,返回 false 。
98 0
|
前端开发 算法 JavaScript
LeetCode检查单词是否为句中其他单词的前缀使用JavaScript解题|前端学算法
LeetCode检查单词是否为句中其他单词的前缀使用JavaScript解题|前端学算法
97 0
LeetCode检查单词是否为句中其他单词的前缀使用JavaScript解题|前端学算法
LeetCode每日一题(26)——高度检查器
高度检查器 1.题目 2.示例 3.思路 4.代码
109 0
|
算法
【Day20】LeetCode算法题【1784. 检查二进制字符串字段】【14. 最长公共前缀】
了解LeetCode算法题【1784. 检查二进制字符串字段】。
117 0
【Day20】LeetCode算法题【1784. 检查二进制字符串字段】【14. 最长公共前缀】
|
机器学习/深度学习
LeetCode contest 190 5416. 检查单词是否为句中其他单词的前缀
LeetCode contest 190 5416. 检查单词是否为句中其他单词的前缀