贪心算法(无规则)

news2025/2/25 2:43:06

目录

  • 1.easy
      • 1.455. 分发饼干
      • 2.1005. K 次取反后最大化的数组和
      • 3.860. 柠檬水找零
  • 2.medium
    • 1.序列问题
      • 1.376. 摆动序列
      • 2.738. 单调递增的数字
    • 2.贪心解决股票问题
      • 1.122. 买卖股票的最佳时机 II
    • 3.两个维度权衡问题
      • 1.135. 分发糖果
      • *2.406. 根据身高重建队列(linklist,labmda表达式)
  • 3.hard
    • 1.区间问题
      • 1.55. 跳跃游戏
      • 2.45. 跳跃游戏 II
      • 3.452. 用最少数量的箭引爆气球
      • 4.435. 无重叠区间
      • 5.763. 划分字母区间
      • 6.56. 合并区间
    • 2.其他
      • 1.53. 最大子数组和
      • 2.134. 加油站

1.easy

1.455. 分发饼干

链接: 455. 分发饼干
在这里插入图片描述

class Solution {
    public int findContentChildren(int[] g, int[] s) {
        Arrays.sort(g);
        Arrays.sort(s);
        int res=0;
        int index=s.length-1;
        for(int i=g.length-1;i>=0;i--){
            if(index>=0&&g[i]<=s[index]){
                res++;
                index--;
            }
        }
        return res;
    }
}

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

链接: 1005. K 次取反后最大化的数组和
在这里插入图片描述

class Solution {
    public int largestSumAfterKNegations(int[] nums, int k) {
        //1.给数组排序
        Arrays.sort(nums);
        for(int i=0;i<nums.length;i++){
            if(k>0&&nums[i]<0){//满足条件
                nums[i]=Math.abs(nums[i]);//将目前绝对值最大的负数变为正数
                k--;
            }else{//k==0或者没有负数了退出循环
                break;
            }
        }
        if(k%2==1){//如果剩余k的值为奇数,
            Arrays.sort(nums);//给当前全为正数的数组排序,
            nums[0]=-1*nums[0];//num[0]为最小值取反
        }
        return Arrays.stream(nums).sum();
    }
}

3.860. 柠檬水找零

链接: 860. 柠檬水找零

class Solution {
    public boolean lemonadeChange(int[] bills) {
        int five=0,ten=0,twenty=0;
        for(int i:bills){
            if(i==5){
                five++;
            }else if(i==10){
                if(five==0){
                    return false;
                }else{
                    five--;
                    ten++;
                }
            }else if(i==20){
                if(five!=0&&ten!=0){
                    five--;
                    ten--;
                    twenty++;
                }else if(five>=3){
                    five-=3;
                }else{
                    return false;
                }
            }
        }
        return true;
    }
}

2.medium

1.序列问题

1.376. 摆动序列

链接: 376. 摆动序列
在这里插入图片描述
贪心解法

class Solution {
    public int wiggleMaxLength(int[] nums) {
        if (nums.length <= 1) {
            return nums.length;
        }
        //当前差值
        int curDiff = 0;
        //上一个差值
        int preDiff = 0;
        int res = 1;
        for (int i = 1; i < nums.length; i++) {
            //得到当前差值
            curDiff = nums[i] - nums[i - 1];
            //如果当前差值和上一个差值为一正一负
            //等于0的情况表示初始时的preDiff
            if ((curDiff>0&&preDiff<=0)||(curDiff<0&&preDiff>=0)){
                res++;
                preDiff=curDiff;
            }
        }
        return res;
    }
}

2.738. 单调递增的数字

链接: 738. 单调递增的数字
在这里插入图片描述

class Solution {
    public int monotoneIncreasingDigits(int n) {
        String s = String.valueOf(n);
        char[] chars = s.toCharArray();
        int start = Integer.MAX_VALUE;
        for(int i=s.length()-2;i>=0;i--){
            if(chars[i]>chars[i+1]){
                chars[i]--;
                start=i+1;
            }
        }
        for(int i=start;i<s.length();i++){
            chars[i]='9';
        }
        return Integer.parseInt(String.valueOf(chars));
    }
}

2.贪心解决股票问题

1.122. 买卖股票的最佳时机 II

链接: 122. 买卖股票的最佳时机 II
在这里插入图片描述

//2.贪心解法
class Solution {
    public int maxProfit(int[] prices) {
        int n=prices.length;
        if(n==0){
            return 0;
        }
        int result=0;
        for(int i=1;i<n;i++){
            if(prices[i]-prices[i-1]>0){
                result+=prices[i]-prices[i-1];
            }
        }
        return result;
    }
}

//1.动态规划解法
// class Solution {
//     public int maxProfit(int[] prices) {
//         int n=prices.length;
//         if(n==0){
//             return 0;
//         }
//         int [][]dp=new int[n][2];
//         dp[0][0]=-prices[0];
//         dp[0][1]=0;
//         for(int i=1;i<n;i++){
               //持有股票
//             dp[i][0]=Math.max(dp[i-1][0],dp[i-1][1]-prices[i]);//和1唯一不同
               //不持有股票
//             dp[i][1]=Math.max(dp[i-1][1],prices[i]+dp[i-1][0]);
//         }
//         return dp[n-1][1];
//     }
// }

3.两个维度权衡问题

1.135. 分发糖果

链接: 135. 分发糖果
在这里插入图片描述

class Solution {
    public int candy(int[] ratings) {
        /**
         分两个阶段
         1、起点下标1 从左往右,只要 右边 比 左边 大,右边的糖果=左边 + 1
         2、起点下标 ratings.length-2 从右往左,只要左边比右边大,此时左边的糖果应该 取本身的糖果数(符合比它左边大)和右边糖果数 + 1 二者的最大值,这样才符合 它比它左边的大,也比它右边大
    */
        int candy[]=new int[ratings.length];
        candy[0]=1;
        for(int i=0;i<ratings.length-1;i++){
            if(ratings[i]<ratings[i+1]){//从左向右排
                candy[i+1]=candy[i]+1;
            }else{
                candy[i+1]=1;
            }
        }
        for(int i=ratings.length-2;i>=0;i--){
            if(ratings[i]>ratings[i+1]){//从右向左排
                candy[i]=Math.max(candy[i],candy[i+1]+1);
            }
        }
        int ans = 0;
        for (int num : candy) {
            ans += num;
        }
        return ans;
    }
}

*2.406. 根据身高重建队列(linklist,labmda表达式)

链接: 406. 根据身高重建队列
在这里插入图片描述

class Solution {
    public int[][] reconstructQueue(int[][] people) {
        // 身高从大到小排(身高相同k小的站前面)
        Arrays.sort(people, (a, b) -> {
            if (a[0] == b[0]) return a[1] - b[1];
            return b[0] - a[0];
        });

        LinkedList<int[]> que = new LinkedList<>();

        for (int[] p : people) {
            que.add(p[1],p);
        }

        return que.toArray(new int[people.length][]);
    }
}

3.hard

1.区间问题

1.55. 跳跃游戏

链接: 55. 跳跃游戏
在这里插入图片描述

class Solution {
    public boolean canJump(int[] nums) {
        //覆盖范围, 初始覆盖范围应该是0,因为下面的迭代是从下标0开始的
        int cover=0;
        //在覆盖范围内更新最大的覆盖范围
        for(int i=0;i<=cover;i++){
            cover=Math.max(cover,i+nums[i]);
            if(cover>=nums.length-1){
                return true;
            }
        }
        return false;
    }
}

2.45. 跳跃游戏 II

链接: 45. 跳跃游戏 II
在这里插入图片描述

class Solution {
    public int jump(int[] nums) {
        int n=nums.length;
        if(n==1) return 0;
        int curDistance = 0;    // 当前覆盖最远距离下标
        int ans = 0;            // 记录走的最大步数
        int nextDistance = 0;   // 下一步覆盖最远距离下标
        for(int i=0;i<n;i++){
            // 更新下一步覆盖最远距离下标
            nextDistance = Math.max(nums[i] + i, nextDistance);  
            // 遇到当前覆盖最远距离下标
            if (i == curDistance) {                    
                // 如果当前覆盖最远距离下标不是终点     
                if (curDistance < n - 1) {       
                    ans++; // 需要走下一步
                    // 更新当前覆盖最远距离下标(相当于加油了)
                    curDistance = nextDistance;            
                    // 下一步的覆盖范围已经可以达到终点,结束循环 
                    if (nextDistance >= n - 1) 
                        break; 
                } else // 当前覆盖最远距到达集合终点,不用做ans++操作了,直接结束
                    break;                               
            }
        }
        return ans;
    }
}

3.452. 用最少数量的箭引爆气球

链接: 452. 用最少数量的箭引爆气球

/**
 * 时间复杂度 : O(NlogN)  排序需要 O(NlogN) 的复杂度
 * 空间复杂度 : O(logN) java所使用的内置函数用的是快速排序需要 logN 的空间
 */
class Solution {
    public int findMinArrowShots(int[][] points) {
        // 根据气球直径的开始坐标从小到大排序
        // 使用Integer内置比较方法,不会溢出
        Arrays.sort(points, (a, b) -> Integer.compare(a[0], b[0]));

        int count = 1;  // points 不为空至少需要一支箭
        for (int i = 1; i < points.length; i++) {
            // 气球i和气球i-1不挨着,注意这里不是>=
            if (points[i][0] > points[i - 1][1]) {  
                count++; // 需要一支箭
            } else {  // 气球i和气球i-1挨着
            // 更新重叠气球最小右边界
                points[i][1] = Math.min(points[i][1], points[i - 1][1]); 
            }
        }
        return count;
    }
}

4.435. 无重叠区间

链接: 435. 无重叠区间

class Solution {
    public int eraseOverlapIntervals(int[][] intervals) {
        //按照左边界排序
        Arrays.sort(intervals, (a,b)-> {
            return Integer.compare(a[0],b[0]);
        });
        int remove = 0;
        int pre = intervals[0][1];//初始化最左边的区间最右边界为pre
        for(int i = 1; i < intervals.length; i++) {
            if(pre > intervals[i][0]) {//重叠
                remove++;
                pre = Math.min(pre, intervals[i][1]);
            }
            else pre = intervals[i][1];
        }
        return remove;
    }
}

5.763. 划分字母区间

链接: 763. 划分字母区间
在这里插入图片描述

class Solution {
    public List<Integer> partitionLabels(String s) {
        List<Integer> result=new ArrayList<>();
        int len=s.length();
        //记录每个字母最后出现的位置
        int hush[]=new int[27];
        for(int i=0;i<len;i++){
            hush[s.charAt(i)-'a']=i;
        }
        int right=0;
        int left=0;
        for(int i=0;i<len;i++){
            right=Math.max(right,hush[s.charAt(i)-'a']);
            if(i==right){// 找到字符出现的最远边界
                result.add(right-left+1);
                left=right+1;
            }
        }
        return result;
    }
}

6.56. 合并区间

链接: 56. 合并区间
在这里插入图片描述

class Solution {
    public int[][] merge(int[][] intervals) {
         List<int[]> res = new LinkedList<>();
        //按照左边界排序
        Arrays.sort(intervals, (x, y) -> Integer.compare(x[0], y[0]));
        //initial start 是最小左边界
        int start = intervals[0][0];
        int mostRightIndex = intervals[0][1];
        for(int i=1;i<intervals.length;i++){
            //如果左边界大于最大右边界
            if(intervals[i][0]>mostRightIndex){
                res.add(new int[]{start,mostRightIndex});
                start=intervals[i][0];
                mostRightIndex=intervals[i][1];
            }else{//如果左边界小于最大右边界
                //更新最大右边界
                mostRightIndex = Math.max(mostRightIndex, intervals[i][1]);
            }
        }
        res.add(new int[]{start, mostRightIndex});
        return res.toArray(new int[res.size()][]);
    }
}

2.其他

1.53. 最大子数组和

链接: 53. 最大子数组和
在这里插入图片描述
贪心解法

class Solution {
    public int maxSubArray(int[] nums) {
        if (nums.length == 1){
            return nums[0];
        }
        int sum = Integer.MIN_VALUE;
        int count = 0;
        for (int i = 0; i < nums.length; i++){
            count += nums[i];
            sum = Math.max(sum, count); // 取区间累计的最大值(相当于不断确定最大子序终止位置)
            if (count <= 0){
                count = 0; // 相当于重置最大子序起始位置,因为遇到负数一定是拉低总和
            }
        }
       return sum;
    }
}

动态规划

class Solution {
    /**
     * 1.dp[i]代表当前下标对应的最大值
     * 2.递推公式 dp[i] = max (dp[i-1]+nums[i],nums[i]) res = max(res,dp[i])
     * 3.初始化 都为 0
     * 4.遍历方向,从前往后
     * 5.举例推导结果。。。
     *
     * @param nums
     * @return
     */
    public int maxSubArray(int[] nums) {
        if (nums.length == 0) {
            return 0;
        }

        int res = nums[0];
        int[] dp = new int[nums.length];
        dp[0] = nums[0];
        for (int i = 1; i < nums.length; i++) {
            dp[i] = Math.max(dp[i - 1] + nums[i], nums[i]);
            res = res > dp[i] ? res : dp[i];
        }
        return res;
    }


}

2.134. 加油站

链接: 134. 加油站
在这里插入图片描述

class Solution {
    public int canCompleteCircuit(int[] gas, int[] cost) {
        int curSum = 0;
        int totalSum = 0;
        int index = 0;
        for (int i = 0; i < gas.length; i++) {
            curSum += gas[i] - cost[i];
            totalSum += gas[i] - cost[i];
            if (curSum < 0) {
                index = (i + 1) % gas.length ; 
                curSum = 0;
            }
        }
        if (totalSum < 0) return -1;
        return index;
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/522165.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【WOA-LSTM】基于WOA优化 LSTM神经网络预测研究(Python代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

Neuron 2.4.0 发布:体验下一代工业物联网连接和管理

近日&#xff0c;EMQ 旗下的工业协议网关软件 Neuron 发布了最新的 2.4.0 版本。 该版本新增了包括 ABB COMLI 在内的四个南向驱动和一个北向应用&#xff0c;同时对现有的插件功能和 UI 进行了优化。 快速体验 Neuron 新版本 新增驱动插件满足不同场景需求 IEC61850 MMS 和 …

springboot项目如何优雅停机

文章目录 前言kill -9 pid的危害如何优雅的停机理论步骤优雅方式1、kill -15 pid 命令停机2、ApplicationContext close停机3、actuator shutdown 停机 前言 相信很多同学都会用Kill -9 PID来杀死进程&#xff0c;如果用在我们微服务项目里面&#xff0c;突然杀死进程会有什么…

计算机组成原理基础练习题第二章

1.下面四种语言中&#xff0c;()更适应网络环境 A、FORTRAN    B、JavaC、C        D、PASCAL 2.下列叙述中正确的是&#xff08;&#xff09; A.终端是计算机硬件的一部分,好比电视中的小屏幕 B. ALU是代数逻辑单元的缩写 C.导航用计算机属于一般用途计算…

网络数据链路层介绍

文章目录 一、以太网二、以太网的帧格式三、局域网通信的原理四、ARP协议1.ARP协议的介绍2.ARP协议的工作流程3.ARP数据报格式 一、以太网 以太网并不是一种具体的网络&#xff0c;而是一种技术标准&#xff0c;它既包含了数据链路层的内容&#xff0c;也包含了一些物理层的内…

【数据分享】2023年全国A级景区数据(14847个景区)

我国的旅游景区&#xff0c;依据景区质量划分为五级&#xff0c;从高到低依次为5A、4A、3A、2A、A级旅游景区。我国旅游管理部门对于A级景区实行“有进有出”的动态管理&#xff0c;也就是A级景区的名单每年都在变&#xff01;我们立方数据学社也一直在跟踪整理每年的A级景区数…

Android面试指南:说说你对组件化/模块化的理解

到现在组件化真的不是什么新鲜东西了&#xff0c;大公司都用的滚瓜烂熟&#xff0c;龙飞凤舞了&#xff0c;也就是现在部分中型项目和小项目在组件化的路上努力。所以同志们&#xff0c;组件化没玩过的&#xff0c;不熟悉的赶紧搞起来&#xff0c;说一点&#xff0c;你不会组件…

【牛客小白月赛72】BCD题

B、数数 比赛AC代码&#xff1a; #include <iostream> using namespace std;int t, n; int ans1;int check(int x) {int ans 0;for(int i 1; i < x/i; i)if(x%i 0){ans ;if(i ! x/i) ans;}ans1 ans;return ans1; } int main() {cin>> t;while(t--){cin&…

每日一练 | 华为认证真题练习Day44

1、如Display信息所示&#xff0c;当此交换机需要转发目的IAC地址为5489-98ec-f011的帧时&#xff0c;下面描述正确的是&#xff08;&#xff09;。 A. 交换机将会在除了收到该帧的端口之外的所有端口泛洪该帧 B. 交换机将会发送目标不可达的消息给源设备 C. 交换机在MAC地址…

easyExcel 与 POI 基础知识

文章目录 POI 与 easyExcel一、 了解1.1 Apache POI1.2 easyExcel 二、 准备工作2.1 Maven坐标2.2 Excel讲解 三、 Excel基本写操作&#xff08;导出Excel&#xff09;3.1 03 版本Excel导出操作3.2 07版本Excel导出操作3.3 大数据量的导出&#xff08;数据批量导入到磁盘&#…

含电动汽车的区域综合能源系统优化调度研究(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

django路由(多应用配置动态路由正则路由)

一、配置全局路由 在应用下&#xff0c;定义视图函数views.py from django.http import HttpResponse from django.shortcuts import render# Create your views here.def get_order(request):return HttpResponse("orders应用下的路由") 在项目的urls路由配置中&…

输入URL到显示界面的整个过程

以如下这个比较简单的网络拓扑模型作为例子&#xff0c;探究中间发生的整个过程&#xff1a; 1 HTTP 浏览器做的第一步工作就是要对 URL 进行解析&#xff0c;从而生成发送给 Web 服务器的请求信息。下图展示了一条长长的URL里各个元素代表什么&#xff1a; 所以整个长长的URL…

〖C++11〗智能指针详解

「前言」文章是关于C11的智能指针方面 「归属专栏」C嘎嘎 「笔者」枫叶先生(fy) 「座右铭」前行路上修真我 「枫叶先生有点文青病」 「每篇一句」 人生就是一列开往坟墓的列车&#xff0c; 路途上会有很多站&#xff0c; 很难有人自始至终陪着你走完。 当陪你的人要下车时&am…

42个网工高效率工具,我只告诉你(二)

晚上好&#xff0c;我是老杨。好用工具上期更新之后&#xff0c;不少小友催我更新下期&#xff0c;这不就来了&#xff1f; 今日文章阅读福利&#xff1a;《42个好用工具下载包》 私信老杨&#xff0c;回复关键词“工具42”&#xff0c;领取2022网工好用工具大全&#xff0c;同…

软件工程师,要么不写代码,要么就写优雅的代码

何为优雅的代码 优雅的代码&#xff0c;至少需要遵循以下几个原则&#xff1a; 遵守规范 优雅的代码&#xff0c;首先让人看起来就是很整洁的。而这种整洁&#xff0c;则来源于代码规范。严格地遵守代码规范&#xff0c;是提高且保证代码质量的最有效方法。从个人开发的角度来看…

【Python入门】Python的判断语句(判断语句的嵌套)

前言 &#x1f4d5;作者简介&#xff1a;热爱跑步的恒川&#xff0c;致力于C/C、Java、Python等多编程语言&#xff0c;热爱跑步&#xff0c;喜爱音乐的一位博主。 &#x1f4d7;本文收录于Python零基础入门系列&#xff0c;本专栏主要内容为Python基础语法、判断、循环语句、函…

Linux高级(shell)

文章目录 一、shell概述Linux 提供的 Shell 解析器有bash 和 sh 的关系Centos 默认的解析器是 bash 二、shell脚本入门脚本格式第一个shell脚本&#xff1a;helloworld.sh 三、变量系统预定义变量自定义变量特殊变量 四、删除变量五、运算符六、条件判断七、流程控制if判断case…

猜谜游戏、彩云词典爬虫、SOCKS5代理的 Go(Golang) 小实践,附带全代码解释

猜谜游戏在编程语言实践都已经和 HelloWord 程序成为必不可少的新手实践环节&#xff0c;毕竟&#xff0c;它能够让我们基本熟悉 for 循环、变量定义、打印、if else 语句等等的使用&#xff0c;当我们基本熟悉该语言基础之后&#xff0c;就要学会其优势方面的程序实践&#xf…

基本类型的比较VS引用类型的比较

基本类型的比较VS引用类型的比较 数据类型的介绍 类型的比较&#xff0c;在Java中有两种数据类型&#xff0c;一种是基本数据类型&#xff0c;一中是引用类型。 基本数据类型包含一些我们常用的数据&#xff1a; 类型类型名称byte字节型int整型char字符型double浮点型boole…