当前位置:网站首页>LeetCode_逆向思维_中等_453.最小操作次数使数组元素相等
LeetCode_逆向思维_中等_453.最小操作次数使数组元素相等
2022-08-05 18:48:00 【小城老街】
1.题目
给你一个长度为 n 的整数数组,每次操作将会使 n - 1 个元素增加 1 。返回让数组所有元素相等的最小操作次数。
示例 1:
输入:nums = [1,2,3]
输出:3
解释:
只需要3次操作(注意每次操作会增加两个元素的值):
[1,2,3] => [2,3,3] => [3,4,3] => [4,4,4]
示例 2:
输入:nums = [1,1,1]
输出:0
提示:
n == nums.length
1 <= nums.length <= 105
-109 <= nums[i] <= 109
答案保证符合 32-bit 整数
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/minimum-moves-to-equal-array-elements
2.思路
(1)逆向思维
① 如果直接求解发现有点困难,而仔细分析可知:本题最终的结果要求返回让数组所有元素相等的最小操作次数,而每次操作使 n - 1 个元素增加 1,在不考虑数组中具体元素值大小的前提下,该操作等价于使 1 个元素减少 1。所以本题可以等价于每次操作使 1 个元素减少 1,返回让数组所有元素相等的最小操作次数。
② 这样一来,题目就简单了许多,我们只需先求出数组 nums 中的最小值 minNum 以及所有元素之和 sum,由于每次操作使 1 个元素减少 1,那么最终使数组 nums 中所有元素相等的最小操作次数 res = sum - minNum * nums.length。
3.代码实现(Java)
//思路1————逆向思维
class Solution {
public int minMoves(int[] nums) {
int res = 0;
int n = nums.length;
// minNum 为数组 nums 中的最小值,初始值设为 nums[0]
int minNum = nums[0];
// sum 为数组 nums 中所有元素之和
int sum = 0;
for (int num : nums) {
minNum = Math.min(minNum, num);
sum += num;
}
return sum - minNum * n;
}
}
边栏推荐
猜你喜欢
随机推荐
企业数据治理面临的 6 大挑战!
金仓数据库 KingbaseGIS 使用手册(5. 使用几何对象:构建应用)
Redis(三)session共享
物联网技术融合:ZETA联盟会员推出支持ZETA通信协议的BLE蓝牙网关
How to correctly access the real-time recording interface of the national standard video cloud service EasyGBS?
数据围栏简述
最出名的那些日历APP,结果一点都不够好用...
软测人面试 ,HR 会问到哪些问题?学会涨薪3000+
金仓数据库 KingbaseGIS 使用手册(4. 数据管理和查询)
浏览器窗口尺寸相关的 API 整理图
花一星期折腾后,我劝你好好考虑下书签同步这个问题
2022NepCTF部分WP
2022NepCTF Partial WP
张高兴的 .NET IoT 入门指南:(八)基于 GPS 的 NTP 时间同步服务器
rhcsa 学习笔记(持续更新)
荣威RX9年内上市 荣威公布未来产品计划
锁的简单理解
防火墙的目标地址转换和源地址转换
真正靠谱的手机清理APP与方法,轻松帮你干掉几个G垃圾!
申万宏源证券新手开户,安全吗?









