首页 > 其他 > 详细

[leetcode-453-Minimum Moves to Equal Array Elements]

时间:2017-07-03 11:41:35      阅读:290      评论:0      收藏:0      [点我收藏+]

Given a non-empty integer array of size n, find the minimum number of moves required to make all array elements equal, where a move is incrementing n - 1 elements by 1.

Example:

Input:
[1,2,3]

Output:
3

Explanation:
Only three moves are needed (remember each move increments two elements):

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

 

 思路:

参考自:https://discuss.leetcode.com/topic/66737/it-is-a-math-question

let‘s define sum as the sum of all the numbers, before any moves; minNum as the min number int the list; n is the length of the list;

After, say m moves, we get all the numbers as x , and we will get the following equation

 sum + m * (n - 1) = x * n

and actually,

  x = minNum + m

and finally, we will get

  sum - minNum * n = m

So, it is clear and easy now.

 

int minMoves(vector<int>& nums)
     {
         int ret = 0;
         int smallest = *min_element(nums.begin(), nums.end());
         for (auto a:nums)
         {
             ret += (a - smallest);
         }
         return ret;
     }

 

 

 

 

[leetcode-453-Minimum Moves to Equal Array Elements]

原文:http://www.cnblogs.com/hellowooorld/p/7109768.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!