力扣第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;
    }
}

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

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

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

相关推荐
liebe1*127 分钟前
C语言程序代码(四)
c语言·数据结构·算法
进击的圆儿42 分钟前
递归专题4 - 网格DFS与回溯
数据结构·算法·递归回溯
程序猿20231 小时前
Python每日一练---第一天:买卖股票的最佳时机
算法
夏鹏今天学习了吗1 小时前
【LeetCode热题100(56/100)】组合总和
算法·leetcode·职场和发展
ZPC82102 小时前
opencv 获取图像中物体的坐标值
人工智能·python·算法·机器人
颇有几分姿色2 小时前
密码学算法分类指南
算法·密码学
绝无仅有2 小时前
某游戏大厂的 Redis 面试必问题解析
后端·算法·面试
微笑尅乐2 小时前
三种方法解开——力扣3370.仅含置位位的最小整数
python·算法·leetcode
MMjeaty2 小时前
查找及其算法
c++·算法
寂静山林3 小时前
UVa 1597 Searching the Web
数据结构·算法