【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; // 返回最小移除次数
}

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

相关推荐
Kaltistss31 分钟前
98.验证二叉搜索树
算法·leetcode·职场和发展
知己如祭35 分钟前
图论基础(DFS、BFS、拓扑排序)
算法
mit6.82444 分钟前
[Cyclone] 哈希算法 | SIMD优化哈希计算 | 大数运算 (Int类)
算法·哈希算法
c++bug1 小时前
动态规划VS记忆化搜索(2)
算法·动态规划
哪 吒1 小时前
2025B卷 - 华为OD机试七日集训第5期 - 按算法分类,由易到难,循序渐进,玩转OD(Python/JS/C/C++)
python·算法·华为od·华为od机试·2025b卷
军训猫猫头1 小时前
1.如何对多个控件进行高效的绑定 C#例子 WPF例子
开发语言·算法·c#·.net
success2 小时前
【爆刷力扣-数组】二分查找 及 衍生题型
算法
Orlando cron2 小时前
数据结构入门:链表
数据结构·算法·链表
牛客企业服务3 小时前
2025年AI面试推荐榜单,数字化招聘转型优选
人工智能·python·算法·面试·职场和发展·金融·求职招聘
糖葫芦君4 小时前
Policy Gradient【强化学习的数学原理】
算法