【LeetCode每日一题】2171. 拿出最少数目的魔法豆

2024-1-18

文章目录

2171. 拿出最少数目的魔法豆
思路:
  1. 对输入的数组进行排序,使得数组中的元素按照升序排列。
  2. 初始化一个变量s用于存储数组中所有元素的和,并遍历数组将每个元素加到s中,计算数组中所有元素的和。
  3. 初始化一个变量ans用于存储最终结果,默认值为s。
  4. 遍历数组中的每个元素,计算移除该元素后,剩余元素的和(即将数组总和减去该元素乘以剩余元素数量),并将其与之前的最小值进行比较取较小值,更新ans。
  5. 返回最小移除次数,即最小的和值。
java 复制代码
public long minimumRemoval(int[] beans) {
    Arrays.sort(beans); // 对输入数组进行排序,使得数组中的元素按照升序排列
    long s = 0; // 初始化一个变量s用于存储数组中所有元素的和
    for (int x : beans) {
        s += x; // 遍历数组,将每个元素加到s中,计算数组中所有元素的和
    }
    long ans = s; // 初始化一个变量ans用于存储最终结果,默认值为s
    int n = beans.length; // 获取数组的长度
    for (int i = 0; i < n; ++i) { // 遍历数组中的每个元素
        ans = Math.min(ans, s - (long) beans[i] * (n - i)); // 更新ans,将当前元素与剩余元素的和相减,并与ans比较取较小值
    }
    return ans; // 返回最小移除次数
}

点击移步博客主页,欢迎光临~

相关推荐
__AtYou__35 分钟前
Golang | Leetcode Golang题解之第448题找到所有数组中消失的数字
leetcode·golang·题解
阿史大杯茶38 分钟前
Codeforces Round 976 (Div. 2 ABCDE题)视频讲解
数据结构·c++·算法
LluckyYH1 小时前
代码随想录Day 58|拓扑排序、dijkstra算法精讲,题目:软件构建、参加科学大会
算法·深度优先·动态规划·软件构建·图论·dfs
转调1 小时前
每日一练:地下城游戏
开发语言·c++·算法·leetcode
不穿格子衬衫2 小时前
常用排序算法(下)
c语言·开发语言·数据结构·算法·排序算法·八大排序
wdxylb2 小时前
使用C++的OpenSSL 库实现 AES 加密和解密文件
开发语言·c++·算法
aqua35357423582 小时前
蓝桥杯-财务管理
java·c语言·数据结构·算法
CV金科2 小时前
蓝桥杯—STM32G431RBT6(IIC通信--EEPROM(AT24C02)存储器进行通信)
stm32·单片机·嵌入式硬件·算法·蓝桥杯
sewinger2 小时前
区间合并算法详解
算法
XY.散人2 小时前
初识算法 · 滑动窗口(1)
算法