力扣-贪心-1【算法学习day.71】

前言

###我做这类文章一个重要的目的还是给正在学习的大家提供方向和记录学习过程(例如想要掌握基础用法,该刷哪些题?)我的解析也不会做的非常详细,只会提供思路和一些关键点,力扣上的大佬们的题解质量是非常非常高滴!!!


习题

1.重新分装苹果

题目链接: 3074. 重新分装苹果 - 力扣(LeetCode)

题面:

**分析:**优先用容量大的箱子即可

代码:

java 复制代码
class Solution {
    public int minimumBoxes(int[] apple, int[] capacity) {
        int sum = 0;
        for(int a:apple)sum+=a;
        Arrays.sort(capacity);
        int count = 0;
        for(int i = capacity.length-1;i>=0;i--){
            count++;
            sum-=capacity[i];
            if(sum<=0)return count;
        }
        return 0;
    }
}

2.装满石头的背包的最大数量

题目链接: 2279. 装满石头的背包的最大数量 - 力扣(LeetCode)

题面:

**分析:**预处理出差值数组,然后优先最少的即可

代码:

java 复制代码
class Solution {
    public int maximumBags(int[] capacity, int[] rocks, int additionalRocks) {
        int n = capacity.length;
        for(int i = 0;i<n;i++){
            capacity[i]-=rocks[i];
        }
        Arrays.sort(capacity);
        int count = 0;
        for(int i = 0;i<n;i++){
            if(capacity[i]>additionalRocks)return count;
            count++;
            additionalRocks-=capacity[i];
        }
        return count;
    }
}

3.雪糕的最大数量

题目链接: 1833. 雪糕的最大数量 - 力扣(LeetCode)

题面:

代码:

java 复制代码
class Solution {
    public int maxIceCream(int[] costs, int coins) {
        Arrays.sort(costs);
        int count = 0;
        for(int a:costs){
            if(a>coins)return count;
            count++;
            coins-=a;
        }
        return count;
    }
}

4.K次取反后最大化的数组和

题目链接: 1005. K 次取反后最大化的数组和 - 力扣(LeetCode)

题面:

**分析:**先排序,然后优先让最小的负数编程正数,如果k有多余,再次排序,让最小的那个数进行剩下的操作

代码:

java 复制代码
class Solution {
    public int largestSumAfterKNegations(int[] nums, int k) {
        Arrays.sort(nums);
        int n = nums.length;
        for(int i = 0;i<n&&nums[i]<=0&&k>0;i++){
            k--;
            nums[i] = -nums[i];
        }
        if(k>0){
            Arrays.sort(nums);
            k%=2;
            nums[0] = k==1?-nums[0]:nums[0];
        }
        int sum = 0;
        for(int i = 0;i<n;i++){
            sum+=nums[i];
        }
        return sum;
    }
}

后言

上面是力扣贪心专题,下一篇是其他的习题,希望有所帮助,一同进步,共勉!

相关推荐
We་ct2 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
JAVA面经实录9176 小时前
Java企业级工程化·终极完整版背诵手册(无遗漏、全覆盖、面试+落地通用)
java·开发语言·面试
lilihuigz6 小时前
Tutor LMS 4.0 Beta版全新上线:以学习者为中心的移动优先学习体验
学习·在线教育·lms
王老师青少年编程6 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮7 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说7 小时前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
许彰午8 小时前
CacheSQL(二):主从复制——OpLog 环形缓冲区与故障自动恢复
java·数据库·缓存
wuweijianlove8 小时前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung8 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了8 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划