前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LeetCode 训练场:1051. 高度检查器

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

作者头像
村雨遥
发布2022-06-15 10:13:29
1380
发布2022-06-15 10:13:29
举报
文章被收录于专栏:JavaPark

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(nlogn)

)和遍历操作(

O(n)

),所以最终的时间复杂度为

O(nlogn)

.

4. 实现

代码语言:javascript
复制
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;
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-07-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 题目
  • 2. 描述
  • 3. 思路
  • 4. 实现
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档