代码随想录算法训练营day31 | 贪心算法 | 56. 合并区间、738.单调递增的数字

本文主要是介绍代码随想录算法训练营day31 | 贪心算法 | 56. 合并区间、738.单调递增的数字,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 56. 合并区间
      • 思路
    • 738.单调递增的数字
      • 思路
    • 贪心算法专题总结

今天是贪心算法专题的第5天,是贪心算法专题的最后一天

56. 合并区间

建议:本题也是重叠区间问题,如果昨天三道都吸收的话,本题就容易理解了

题目链接:56. 合并区间 - 力扣(LeetCode)

思路

左边界排序数组,记录重叠区间的起始位置start 和 终止位置end。

  • 如果end >= intervals[i] [0],则说明intervals[i]在当前的重叠区间内,更新end = max(end, intervals[i][1]);
  • 否则,intervals[i]不在当前的重叠区间内,将当前重叠区间合并,即result.push_back({start, end}),然后更新start 和 end

代码实现

class Solution {
public:static bool cmp(const vector<int>& a, const vector<int>& b){return a[0] < b[0];}vector<vector<int>> merge(vector<vector<int>>& intervals) {vector<vector<int>> result;sort(intervals.begin(), intervals.end(), cmp);int end = intervals[0][1];int start = intervals[0][0];for(int i=0; i<intervals.size(); ++i){if(end >= intervals[i][0]){end = max(end, intervals[i][1]);}else{result.push_back({start, end});start = intervals[i][0];end = intervals[i][1];}}result.push_back({start, end});	// 不要忘了合并最后一个重叠区间return result;}
};

738.单调递增的数字

题目链接:738. 单调递增的数字 - 力扣(LeetCode)

思路

首先将数字转化为字符串strNum,方便后续处理。本题只需要想清楚个例,例如98,一旦出现strNum[i - 1] > strNum[i]的情况(非单调递增),首先想让strNum[i - 1]减一,strNum[i]赋值9,这样这个整数就是89。就可以很自然想到对应的贪心解法了

这样,我们从后向前遍历,重复利用上次比较得出的结果,找到最后一处strNum[i - 1] > strNum[i]的位置i,用flag记录这个位置i,从flag到末尾都赋值为9,strNum就是最终结果

以332为例,332->329->299,flag=1,从下标1到最后,将所有的位置都赋值9

代码如下

class Solution {
public:int monotoneIncreasingDigits(int n) {string strNum = to_string(n);// flag用来标记赋值9从哪里开始// 设置为这个默认值,为了防止第二个for循环在flag没有被赋值的情况下执行int flag = strNum.size();for(int i=strNum.size()-1; i>0; --i){if(strNum[i-1] > strNum[i]){flag = i; strNum[i-1]--;}}for(int i=flag; i<strNum.size(); ++i){strNum[i] = '9';}return stoi(strNum);}
};

贪心算法专题总结

可以看看贪心算法的总结,贪心本来就没啥规律,能写出个总结篇真的不容易了

代码随想录 (programmercarl.com)

这篇关于代码随想录算法训练营day31 | 贪心算法 | 56. 合并区间、738.单调递增的数字的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1102994

相关文章

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma

深入解析 Java Future 类及代码示例

《深入解析JavaFuture类及代码示例》JavaFuture是java.util.concurrent包中用于表示异步计算结果的核心接口,下面给大家介绍JavaFuture类及实例代码,感兴... 目录一、Future 类概述二、核心工作机制代码示例执行流程2. 状态机模型3. 核心方法解析行为总结:三

python获取cmd环境变量值的实现代码

《python获取cmd环境变量值的实现代码》:本文主要介绍在Python中获取命令行(cmd)环境变量的值,可以使用标准库中的os模块,需要的朋友可以参考下... 前言全局说明在执行py过程中,总要使用到系统环境变量一、说明1.1 环境:Windows 11 家庭版 24H2 26100.4061

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

C#代码实现解析WTGPS和BD数据

《C#代码实现解析WTGPS和BD数据》在现代的导航与定位应用中,准确解析GPS和北斗(BD)等卫星定位数据至关重要,本文将使用C#语言实现解析WTGPS和BD数据,需要的可以了解下... 目录一、代码结构概览1. 核心解析方法2. 位置信息解析3. 经纬度转换方法4. 日期和时间戳解析5. 辅助方法二、L

Python使用Code2flow将代码转化为流程图的操作教程

《Python使用Code2flow将代码转化为流程图的操作教程》Code2flow是一款开源工具,能够将代码自动转换为流程图,该工具对于代码审查、调试和理解大型代码库非常有用,在这篇博客中,我们将深... 目录引言1nVflRA、为什么选择 Code2flow?2、安装 Code2flow3、基本功能演示

IIS 7.0 及更高版本中的 FTP 状态代码

《IIS7.0及更高版本中的FTP状态代码》本文介绍IIS7.0中的FTP状态代码,方便大家在使用iis中发现ftp的问题... 简介尝试使用 FTP 访问运行 Internet Information Services (IIS) 7.0 或更高版本的服务器上的内容时,IIS 将返回指示响应状态的数字代

MySQL 添加索引5种方式示例详解(实用sql代码)

《MySQL添加索引5种方式示例详解(实用sql代码)》在MySQL数据库中添加索引可以帮助提高查询性能,尤其是在数据量大的表中,下面给大家分享MySQL添加索引5种方式示例详解(实用sql代码),... 在mysql数据库中添加索引可以帮助提高查询性能,尤其是在数据量大的表中。索引可以在创建表时定义,也可

使用C#删除Excel表格中的重复行数据的代码详解

《使用C#删除Excel表格中的重复行数据的代码详解》重复行是指在Excel表格中完全相同的多行数据,删除这些重复行至关重要,因为它们不仅会干扰数据分析,还可能导致错误的决策和结论,所以本文给大家介绍... 目录简介使用工具C# 删除Excel工作表中的重复行语法工作原理实现代码C# 删除指定Excel单元