C#LeetCode刷题之#453-最小移动次数使数组元素相等(Minimum Moves to Equal Array Elements)
问题
该文章的最新版本已迁移至个人博客【比特飞】,单击链接 https://www.byteflying.com/archives/3877 访问。
给定一个长度为 n 的非空整数数组,找到让数组所有元素相等的最小移动次数。每次移动可以使 n - 1 个元素增加 1。
输入:[1,2,3]
输出:3
解释:只需要3次移动(注意每次移动会增加两个元素的值):
[1,2,3] => [2,3,3] => [3,4,3] => [4,4,4]
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.
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://www.byteflying.com/archives/3877 访问。
public class Program {
    public static void Main(string[] args) {
        var x = new int[] { 1, 2, 3 };
        var res = MinMoves(x);
        Console.WriteLine(res);
        x = new int[] { 1, 2147483647 };
        res = MinMoves2(x);
        Console.WriteLine(res);
        x = new int[] { 1, 5, 7, 2, 3 };
        res = MinMoves3(x);
        Console.WriteLine(res);
        Console.ReadKey();
    }
    private static int MinMoves(int[] nums) {
        //这个解法未AC,因为nums.Sum()的值有可能会超出整型范围
        return nums.Sum() - nums.Length * nums.Min();
    }
    private static int MinMoves2(int[] nums) {
        var min = nums.Min();
        var sum = 0L;
        foreach (var num in nums) {
            sum += num;
        }
        return (int)(sum - min * nums.Length);
    }
    private static int MinMoves3(int[] nums) {
        var min = nums.Min();
        return nums.Sum(n => n - min);
    }
}以上给出3种算法实现,以下是这个案例的输出结果:
该文章的最新版本已迁移至个人博客【比特飞】,单击链接 https://www.byteflying.com/archives/3877 访问。
3
2147483646
13分析:
该题的解法思路为每次减1个数,使整个数组相等。
显而易见,MinMoves 、MinMoves2 和 MinMoves3 的时间复杂度基于部分函数库的实现,它们的时间复杂度应当均为:  。
C#LeetCode刷题之#453-最小移动次数使数组元素相等(Minimum Moves to Equal Array Elements)的更多相关文章
- LeetCode 453. 最小移动次数使数组元素相等(Minimum Moves to Equal Array Elements) 47
		453. 最小移动次数使数组元素相等 453. Minimum Moves to Equal Array Elements 题目描述 给定一个长度为 n 的非空整数数组,找到让数组所有元素相等的最小移 ... 
- [Swift]LeetCode453. 最小移动次数使数组元素相等 | Minimum Moves to Equal Array Elements
		Given a non-empty integer array of size n, find the minimum number of moves required to make all arr ... 
- Java实现 LeetCode 453 最小移动次数使数组元素相等
		453. 最小移动次数使数组元素相等 给定一个长度为 n 的非空整数数组,找到让数组所有元素相等的最小移动次数.每次移动可以使 n - 1 个元素增加 1. 示例: 输入: [1,2,3] 输出: 3 ... 
- LeetCode#453 最小移动次数使数组元素相等
		给定一个长度为 n 的非空整数数组,找到让数组所有元素相等的最小移动次数.每次移动可以使 n - 1 个元素增加 1. 示例: 输入: [,,] 输出: 解释: 只需要3次移动(注意每次移动会增加两个 ... 
- 力扣(LeetCode)453. 最小移动次数使数组元素相等
		给定一个长度为 n 的非空整数数组,找到让数组所有元素相等的最小移动次数.每次移动可以使 n - 1 个元素增加 1. 示例: 输入: [1,2,3] 输出: 3 解释: 只需要3次移动(注意每次移动 ... 
- 【leetcode】453. Minimum Moves to Equal Array Elements
		problem 453. Minimum Moves to Equal Array Elements 相当于把不等于最小值的数字都减到最小值所需要次数的累加和. solution1: class So ... 
- LeetCode Minimum Moves to Equal Array Elements II
		原题链接在这里:https://leetcode.com/problems/minimum-moves-to-equal-array-elements-ii/ 题目: Given a non-empt ... 
- LeetCode Minimum Moves to Equal Array Elements
		原题链接在这里:https://leetcode.com/problems/minimum-moves-to-equal-array-elements/ 题目: Given a non-empty i ... 
- 453. Minimum Moves to Equal Array Elements 一次改2个数,变成统一的
		[抄题]: Given a non-empty integer array of size n, find the minimum number of moves required to make a ... 
随机推荐
- Ethical Hacking - NETWORK PENETRATION TESTING(22)
			MITM - Wireshark WIreshark is a network protocol analyser that is designed to help network administa ... 
- Ethical Hacking - NETWORK PENETRATION TESTING(5)
			Deauthentication Attacks Theory This attack is used to disconnect any device from any network within ... 
- kubernetes系列(十七) - 通过helm安装dashboard详细教程
			1. 前提条件 2. 配置https证书为secret 3. dashboard安装 3.1 helm拉取dashboard的chart 3.2 配置dashboard的chart包配置 3.3 he ... 
- 资深CIO介绍如何选型OA系统的?
			OA办公系统成为企业管理的标配软件,在于可有效加强组织管理能力,提高员工协同效率,助力企业科学决策,合理分配企业资源,提升企业综合实力与市场竞争力.企业OA选型的经验总结来说也就是品牌.技术.产品.服 ... 
- ASP.Net Core 3.1 With Autofac ConfigureServices returning an System.IServiceProvider isn't supported.
			ASP.Net Core 3.1 With Autofac ConfigureServices returning an System.IServiceProvider isn't supported ... 
- python环境搭建及配置
			我选择的是pycharm,这个对新手比较友好 我目前正在自学周志华的西瓜书,在做练习题3.3时需要用到python来实现,做这个练习需要numpy库和matplot库,最开始的时候忘了anaconda ... 
- 【揭秘】阿里测试框架,各大CTO良心力荐
			自动化测试因其节约成本.提高效率.减少手动干预等优势已经日渐成为测试人员的“潮流”,从业人员日益清楚地明白实现自动化框架是软件自动化项目成功的关键因素之一.本篇文章将从 什么是真正的自动化测试框架.自 ... 
- socket解决半包、粘包问题
			最近项目遇到socket服务端接收报文不全的问题,与其客户端约定的是报文长度+报文体.然而当客户端数据量大的时候,用分包发送,导致服务端报文日志接收不完整,于是想着先读出包体长度,再读出包体,不够就一 ... 
- springboot 跨域设置
			/** * Configuration cors */ @Configuration public class MyConfiguration { @Bean public FilterRegistr ... 
- 面试题五十七:和为s的数字
			题目一:和为s的数字,在一个递增数组中寻找两个数字的和等于s 方法:双指针法,一个在头一个在尾:如果两个指针指向的和小于,那么be++:大于end--: 题目二:打印所有和为s的连续正数序列 方法:双 ... 
