453. 最小操作次数使数组元素相等(求对立事件)

1 - 解题思路

本题求使数组元素相等的最小操作次数,每次操作使n-1个数增加1,直至与最大的那个数,(刚开始拿到问题的时候,总是很自然的跟着题目给的例子想算法,先用位运算判断数组元素是否相等,再找出最大值,对除了最大值外的数依次增加1,如此循环往复直至全部数值相等。)

也可以转化成每次使1个数减少1,直至与最小的那个数相等。因此每次只需要操作一个数,即计算出数组元素每一个数与最小数的差值即为所求最小操作次数。

2 - 解题方法

当一个的正面难解的时候可以想一想它的反面,对立事件。

3 -Code

int minMoves(int* nums, int numsSize){
    int m=0,sum=0,i;
    for(i=1;i<numsSize;i++)
    if(nums[m]>nums[i])m=i;
    for(i=0;i<numsSize;i++)
    {
        sum+=nums[i]-nums[m];
    }
    return sum;
}

4 -算法分析

①时间复杂度:O(n)

②空间复杂度:O(1)

5 - 总结

刚开始拿到问题的时候,总是很自然的跟着题目给的例子想算法,谁知道这道题的算法那么简单,就是一般人根本想不到哇,所以下次下笔之前,得先想想有什么玄机。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值