LeetCode_数组的改变、移动_第453题:最小移动次数使数组元素相等

给定一个长度为 n 的非空整数数组,找到让数组所有元素相等的最小移动次数。每次移动将会使 n - 1 个元素增加 1。

 

示例:

输入:
[1,2,3]

输出:
3

解释:
只需要3次移动(注意每次移动会增加两个元素的值):

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

法一:

###
解题思路:移动次数 m 等于 最终值 x - min(nums) 
###
class Solution:
    def minMoves(self, nums: List[int]) -> int:
        res = 0
        tmp = min(nums)
        size = len(nums)
        for i in range(size):        
            res += nums[i] - tmp      # nums[i] 为 那个不移动的 1 其他的 n - 1 个数移动了     
                                      # nums[i] - min(nums) 次 
                                      # 每个数都有不移动的时候 此时把其他移动的次数记录
                                      # 累加求和得出总移动次数 
        return res
        

法二:

###
解题思路:数学思想
         最后每个数相等 为 x 共有 n = len(nums) 个  总和 x * n
         现在总和 sum(nums), 要移动次数 m 次,每次移动 n - 1 个数 +1
         所以 得出方程式 :
                   x * n == m * (n - 1) * 1 + sum(nums)
          整理得出     m == sum(nums) - len(nums) * min(nums)
###
class Solution:
    def minMoves(self, nums: List[int]) -> int:
        return sum(nums) - len(nums) * min(nums)

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值