码迷,mamicode.com
首页 > 其他好文 > 详细

LeetCode 453 Minimum Moves to Equal Array Elements

时间:2016-11-12 16:41:34      阅读:158      评论:0      收藏:0      [点我收藏+]

标签:style   array   长度   思路   where   nat   mem   class   bsp   

Problem:

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]

Summary:

对于一个长度为n的整型数数组,每步将n-1个元素加1,求最少需要多少步,能使数组中的数字全部相同。

Analysis:

若使数组尽快满足题目要求,则需要每次给除去最大值的其余数字加1,但这种方法效率过低,可以换一种思路。每次将数组中的n-1个数字加1,相当于将剩余的一个数字减1。所以只需找到数组中的最小值m,计算m与数组中其他数字差的累计和即可。

 1 class Solution {
 2 public:
 3     int minMoves(vector<int>& nums) {
 4         sort(nums.begin(), nums.end());
 5         int len = nums.size(), res = 0;
 6         
 7         for (int i = 1; i < len; i++) {
 8             res += nums[i] - nums[0];
 9         }
10         
11         return res;
12     }
13 };

 

LeetCode 453 Minimum Moves to Equal Array Elements

标签:style   array   长度   思路   where   nat   mem   class   bsp   

原文地址:http://www.cnblogs.com/VickyWang/p/6056587.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!