力扣第462题 最小操作次数使数组元素相等 II C++ 排序基础 附Java代码

题目

462. 最小操作次数使数组元素相等 II

中等

相关标签

数组 数学 排序

给你一个长度为 n 的整数数组 nums ,返回使所有数组元素相等需要的最小操作数。

在一次操作中,你可以使数组中的一个元素加 1 或者减 1

示例 1:

复制代码
输入:nums = [1,2,3]
输出:2
解释:
只需要两次操作(每次操作指南使一个元素加 1 或减 1):
[1,2,3]  =>  [2,2,3]  =>  [2,2,2]

示例 2:

复制代码
输入:nums = [1,10,2,9]
输出:16

提示:

  • n == nums.length
  • 1 <= nums.length <= 105
  • -109 <= nums[i] <= 109

思路和解题方法

  1. // 计算使数组所有元素相等所需的最小移动次数:这是对 minMoves2 函数功能的简要描述。

  2. sort(nums.begin(),nums.end());:使用 C++ 的标准库函数 sort 对数组 nums 进行升序排序。

  3. int n = nums.size();:获取数组 nums 的长度,即元素个数。

  4. int ans = 0, x= nums[n/2];:初始化结果变量 ans 为 0,并取中位数作为目标值 x。这里利用了数组已经排序过的特性,直接取排序后的中间值作为目标值。

  5. for(int i = 0;i<n;i++):遍历数组 nums,对每个元素进行处理。

  6. ans +=abs(nums[i] - x);:累加每个元素与目标值 x 的差的绝对值到结果变量 ans 中。这里通过计算每个元素与目标值的差的绝对值来累加移动次数,因为我们的目标是让所有元素相等,所以需要将每个元素移动到目标值 x 所需的步数。

  7. return ans;:将累加结果 ans 作为最小移动次数返回。

复杂度

时间复杂度:

O(n * logn)

时间复杂度为O(n log n),其中n是输入数组nums的长度。这是因为在代码中使用了sort函数对数组进行排序,其时间复杂度为O(n log n)。接下来的for循环需要线性时间O(n)来遍历整个数组,因此整体的时间复杂度为O(n log n + n),即O(n log n)。

空间复杂度

O(1)

空间复杂度则为O(1),因为除了输入数组之外,代码中并没有使用额外的辅助空间,所以空间复杂度是常数级的,为O(1)。

c++ 代码

cpp 复制代码
class Solution {
public:
    // 计算使数组所有元素相等所需的最小移动次数
    int minMoves2(vector<int>& nums) {
        // 对数组进行排序
        sort(nums.begin(),nums.end());
        // 获取数组长度
        int n = nums.size();
        // 初始化结果变量为0,并取中位数作为目标值
        int ans = 0, x= nums[n/2];
        // 遍历数组,累加每个元素与目标值的差的绝对值
        for(int i = 0;i<n;i++)
        {
            ans +=abs(nums[i] - x);
        }
        // 返回累加结果作为最小移动次数
        return ans;
    }
};

Java代码

java 复制代码
class Solution {
    // 计算使数组所有元素相等所需的最小移动次数
    public int minMoves2(int[] nums) {
        // 对数组进行排序
        Arrays.sort(nums);
        // 获取数组长度
        int n = nums.length;
        // 初始化结果变量为0,并取中位数作为目标值
        int ret = 0, x = nums[n / 2];
        // 遍历数组,累加每个元素与目标值的差的绝对值
        for (int i = 0; i < n; i++) {
            ret += Math.abs(nums[i] - x);
        }
        // 返回累加结果作为最小移动次数
        return ret;
    }
}

觉得有用的话可以点点赞,支持一下。

如果愿意的话关注一下。会对你有更多的帮助。

每天都会不定时更新哦 >人< 。

相关推荐
牛客企业服务2 分钟前
2025年AI面试推荐榜单,数字化招聘转型优选
人工智能·python·算法·面试·职场和发展·金融·求职招聘
charlie11451419114 分钟前
深入理解Qt的SetWindowsFlags函数
开发语言·c++·qt·原理分析
呜喵王阿尔萨斯20 分钟前
编程中的英语
c语言·c++
糖葫芦君41 分钟前
Policy Gradient【强化学习的数学原理】
算法
whoarethenext1 小时前
使用 C++/Faiss 加速海量 MFCC 特征的相似性搜索
开发语言·c++·faiss
向阳@向远方2 小时前
第二章 简单程序设计
开发语言·c++·算法
Mr_Xuhhh3 小时前
信号与槽的总结
java·开发语言·数据库·c++·qt·系统架构
github_czy3 小时前
RRF (Reciprocal Rank Fusion) 排序算法详解
算法·排序算法
liulilittle3 小时前
VGW 虚拟网关用户手册 (PPP PRIVATE NETWORK 基础设施)
开发语言·网络·c++·网关·智能路由器·路由器·通信
许愿与你永世安宁4 小时前
力扣343 整数拆分
数据结构·算法·leetcode