当前位置:网站首页>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;
}
}
边栏推荐
- vnt design的日期选择框的坑: a-range-picker 选了时间验证一直不过??
- Redis(三)session共享
- Golang 汇编asm语言基础学习
- 【教程1】疯壳·ARM功能手机-开发板上电教程
- 为什么企业需要使用 Wiki 工具?
- RHCE 作业八(Ansible的三个命令模块和部分文件操模块)
- 【Redis】key命令学习
- 现在的Android 开发面试都会问到一些什么?
- 插槽的三大类
- The pit of the date selection box of vnt design: a-range-picker has selected the time verification, but it still fails??
猜你喜欢

【机器学习】50个最佳机器学习公共数据集

Alibaba billion-level concurrent system design manual has been open source (2022 latest version)

【开源教程1】疯壳·开源编队无人机-开机测试

2.报表平台相关组件预研(1)----jimuReport

EdgeNeXt轻量化学习笔记

MetaFormer/PoolFormer学习笔记及代码

EfficientFormer学习笔记

有主键索引cpu 还是100%

CANoe—基于14229+15765的UDS培训(CAN+CANFD)—无DIVA的UDS自动化测试用例CAPL脚本

2022CISCN华东北复现
随机推荐
VSCode连接远程服务器和本地开发
RHCE 作业一
张高兴的 .NET IoT 入门指南:(八)基于 GPS 的 NTP 时间同步服务器
国标视频云服务EasyGBS如何正确调阅实时录像接口?
浅述量子计算
金仓数据库KingbaseES客户端编程接口指南-JDBC(12. 在应用服务器中配置JDBC)
Qt样式表之 QSS 语法介绍;QLineEdit、
rhcsa 第一次作业
rhcsa 学习笔记(持续更新)
大型数据中心云平台建设中网络的知识及实践
C语言基础知识 -- 初识结构体
LVS负载均衡集群
rhcsa 第二次作业
NOKOV metric motion capture assists the completion of UAV indoor positioning research
Kubernetes的整体架构
为什么企业需要使用 Wiki 工具?
CentOS7安装MySQL8
真正靠谱的手机清理APP与方法,轻松帮你干掉几个G垃圾!
(c语言)初识结构体
“拨”取数字的典例:N位水仙花数判断及水仙花数变种