打卡力扣题目六

简介: 打卡力扣题目六

关于 ARTS 的释义 —— 每周完成一个 ARTS:

● Algorithm: 每周至少做一个 LeetCode 的算法题

● Review: 阅读并点评至少一篇英文技术文章

● Tips: 学习至少一个技术技巧

● Share: 分享一篇有观点和思考的技术文章


希望通过此次活动能聚集一波热爱技术的人,延续好奇、探索、实践、分享的精神。

一、问题

给你一个长度为 n 的整数数组,每次操作将会使 n - 1 个元素增加 1 。返回让数组所有元素相等的最小操作次数。


示例 1:

输入:nums = [1,2,3]

输出:3

解释:

只需要3次操作(注意每次操作会增加两个元素的值):

[1,2,3]  =>  [2,3,3]  =>  [3,4,3]  =>  [4,4,4]


示例 2:

输入:nums = [1,1,1]

输出:0


二、解题方法

def minMoves(nums):
    total = sum(nums)
    avg = total // len(nums)
    return sum(abs(x - avg) for x in nums)

这段代码实现了一个函数 `minMoves`,用于计算将一个整数数组中的所有元素变为相等值所需的最小操作次数。


函数的输入参数为一个整数数组 `nums`。


首先,我们使用 Python 内置函数 `sum()` 对数组中所有元素求和,得到总和 `total`。然后,我们将总和除以数组长度 `len(nums)`,得到平均值 `avg`。


接下来,我们使用列表推导式遍历数组中的每个元素 `x`,并计算它与平均值 `avg` 的差值的绝对值。最后,我们将所有差值的绝对值求和,即为将数组中所有元素变为相等值所需的最小操作次数。


这个算法的时间复杂度为 O(n),其中 n 为数组的长度。


三、解题方法二


除了使用列表推导式计算差值的绝对值,我们还可以使用数学方法来解决这个问题。


假设数组中所有元素都比平均值大 k 个单位,那么将它们全部减去 k 个单位即可让它们变成相等的值。因此,我们需要找到最小的操作次数,使得这些操作可以将所有元素都变为相等的值。


我们可以先计算出数组中所有元素与平均值的差值之和 sum_diff,然后再用这个和除以 k,得到需要进行的操作次数 num_operations。最后,我们将 num_operations 乘以数组长度 len(nums),即为将数组中所有元素变为相等值所需的最小操作次数。


以下是使用这种方法实现的代码:

def minMoves(nums):
    avg = sum(nums) // len(nums)
    sum_diff = sum(abs(x - avg) for x in nums)
    num_operations = sum_diff // (len(nums) - 1)
    return num_operations * len(nums)

这个算法的时间复杂度同样为 O(n),其中 n 为数组的长度。


四、两个方法的区别

这两个方法的区别在于它们的思路不同。第一个方法是先计算出数组中所有元素与平均值的差值之和 `sum_diff`,然后再用这个和除以 k,得到需要进行的操作次数 `num_operations`。最后,我们将 `num_operations` 乘以数组长度 `len(nums)`,即为将数组中所有元素变为相等值所需的最小操作次数。


而第二个方法则是假设数组中所有元素都比平均值大 k 个单位,那么将它们全部减去 k 个单位即可让它们变成相等的值。因此,我们需要找到最小的操作次数,使得这些操作可以将所有元素都变为相等的值。


两种方法的时间复杂度都是 O(n),其中 n 为数组的长度。但是,由于第二种方法假设了数组中所有元素都比平均值大 k 个单位,因此在实际情况中可能会出现误差。


相关文章
|
4天前
|
算法
LeetCode第12题目整数转罗马数字
该文章介绍了 LeetCode 第 12 题整数转罗马数字的解法,通过使用 TreeMap 按照整数从大到小排序,先使用大的罗马数字表示整数,再用小的,核心是先表示完大的罗马数字,想通此点该题较简单。
LeetCode第12题目整数转罗马数字
|
11天前
|
算法 Java
LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
27 6
|
4天前
|
算法
LeetCode第13题目罗马数字转整数
该文章介绍了 LeetCode 第 13 题罗马数字转整数的解法,通过从大到小解析罗马数字,根据罗马数字的特点,按照从大到小的顺序匹配罗马数字和整数的关系,从而解决该问题,同时强调要注意观察题目考查的知识点特征。
|
2月前
|
C语言
详解Leetcode中关于malloc模拟开辟二维数组问题,涉及二维数组的题目所给函数中的各个参数的解读
详解Leetcode中关于malloc模拟开辟二维数组问题,涉及二维数组的题目所给函数中的各个参数的解读
14 1
|
1月前
|
存储 算法
经典的滑动窗口的题目 力扣 2799. 统计完全子数组的数目(面试题)
经典的滑动窗口的题目 力扣 2799. 统计完全子数组的数目(面试题)
|
2月前
|
算法
【经典LeetCode算法题目专栏分类】【第10期】排序问题、股票问题与TOP K问题:翻转对、买卖股票最佳时机、数组中第K个最大/最小元素
【经典LeetCode算法题目专栏分类】【第10期】排序问题、股票问题与TOP K问题:翻转对、买卖股票最佳时机、数组中第K个最大/最小元素
|
2月前
|
容器
【LeetCode刷题】栈和队列题目练习~
【LeetCode刷题】栈和队列题目练习~
【42页动态规划学习笔记分享】动态规划核心原理详解及27道LeetCode相关经典题目汇总(4)
【42页动态规划学习笔记分享】动态规划核心原理详解及27道LeetCode相关经典题目汇总
|
2月前
|
存储 算法
【42页动态规划学习笔记分享】动态规划核心原理详解及27道LeetCode相关经典题目汇总(1)
【42页动态规划学习笔记分享】动态规划核心原理详解及27道LeetCode相关经典题目汇总
|
2月前
|
算法
【经典LeetCode算法题目专栏分类】【第11期】递归问题:字母大小写全排列、括号生成
【经典LeetCode算法题目专栏分类】【第11期】递归问题:字母大小写全排列、括号生成