DAY36: 贪心算法part5区间问题435、763、56

2024-01-31 19:36

本文主要是介绍DAY36: 贪心算法part5区间问题435、763、56,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Leetcode: 435 无重叠区间

和昨天学习的到的打气球的题目属于一样的框架和题型。

基本思路:首先将区间按照左区间从小到大进行排序,判断前面的元素右区间和后面的元素左区间是否重叠,如果重叠了需要统计重叠区间的数量,同时更新区间,选择保留右区间元素较小的那个,防止多次删除的问题。代码如下:

时间复杂度O(nlogn)

空间复杂度O(N)

class Solution {
static bool cmp(const vector<int>& a, const vector<int>& b) {return a[0] < b[0];
}
public:int eraseOverlapIntervals(vector<vector<int>>& intervals) {sort(intervals.begin(), intervals.end(), cmp);//排序int result = 0;for(int i = 1; i < intervals.size(); i++){if(intervals[i][0] < intervals[i - 1][1]){//如果区间重叠了intervals[i][1] = min(intervals[i - 1][1], intervals[i][1]);//保留右区间较小的那个result++;}}return result;}
};

当然这道题还有其他的做法,比如使用左区间排序来减去不重叠的区间,

代码随想录

Leetcode: 763 划分字母区间

基本思路是寻找到遍历过的所有字母的最远编解来划分。

  • 统计每一个字符最后出现的位置
  • 从头遍历字符,并更新字符的最远出现下标,如果找到字符最远出现位置下标和当前下标相等了,则找到了分割点
class Solution {
public:vector<int> partitionLabels(string s) {int count[27] = {0};//因为只有26个字母,所以开一个27的数组来记录每个字母的最远下标for(int i = 0; i < s.size(); i++){count[s[i] - 'a'] = i;//记录最远下标}vector<int> result;int end = 0;//记录上一个划分的分割点int countmax = 0;//记录当前遍历中的最远的字母下标for(int i = 0; i < s.size(); i++){countmax = max(countmax, count[s[i] - 'a']);//更新最远下标if(i == countmax){result.push_back(i - end + 1);//输入结果end = i + 1;//更新结束的分割点}}return result;}
};

Leetcode: 56 合并区间

本质上还是和第一题判断区间的思路差不多,只需要判断一下是不是区间重合,如果区间重合就合并,更新结果。

class Solution {
static bool cmp(const vector<int>& a, const vector<int>& b) {return a[0] < b[0];
}
public:vector<vector<int>> merge(vector<vector<int>>& intervals) {vector<vector<int>> result;if (intervals.size() == 0) return result; // 区间集合为空直接返回sort(intervals.begin(), intervals.end(), cmp);result.push_back(intervals[0]); for (int i = 1; i < intervals.size(); i++) {if(intervals[i][0] <= result.back()[1]){result.back()[1] = max(result.back()[1], intervals[i][1]); //更新结果区间}else{result.push_back(intervals[i]); // 区间不重叠}}return result;}
};

以前的写法

class Solution {
public:vector<vector<int>> merge(vector<vector<int>>& intervals) {sort(intervals.begin(), intervals.end());vector<vector<int>> ans;for (int i = 0; i < intervals.size();) {int t = intervals[i][1];int j = i + 1;while (j < intervals.size() && intervals[j][0] <= t) {t = max(t, intervals[j][1]);j++;}ans.push_back({ intervals[i][0], t });i = j;}return ans;}
};

这篇关于DAY36: 贪心算法part5区间问题435、763、56的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

解决RocketMQ的幂等性问题

《解决RocketMQ的幂等性问题》重复消费因调用链路长、消息发送超时或消费者故障导致,通过生产者消息查询、Redis缓存及消费者唯一主键可以确保幂等性,避免重复处理,本文主要介绍了解决RocketM... 目录造成重复消费的原因解决方法生产者端消费者端代码实现造成重复消费的原因当系统的调用链路比较长的时

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

kkFileView启动报错:报错2003端口占用的问题及解决

《kkFileView启动报错:报错2003端口占用的问题及解决》kkFileView启动报错因office组件2003端口未关闭,解决:查杀占用端口的进程,终止Java进程,使用shutdown.s... 目录原因解决总结kkFileViewjavascript启动报错启动office组件失败,请检查of

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at

Spring的RedisTemplate的json反序列泛型丢失问题解决

《Spring的RedisTemplate的json反序列泛型丢失问题解决》本文主要介绍了SpringRedisTemplate中使用JSON序列化时泛型信息丢失的问题及其提出三种解决方案,可以根据性... 目录背景解决方案方案一方案二方案三总结背景在使用RedisTemplate操作redis时我们针对

Kotlin Map映射转换问题小结

《KotlinMap映射转换问题小结》文章介绍了Kotlin集合转换的多种方法,包括map(一对一转换)、mapIndexed(带索引)、mapNotNull(过滤null)、mapKeys/map... 目录Kotlin 集合转换:map、mapIndexed、mapNotNull、mapKeys、map

nginx中端口无权限的问题解决

《nginx中端口无权限的问题解决》当Nginx日志报错bind()to80failed(13:Permissiondenied)时,这通常是由于权限不足导致Nginx无法绑定到80端口,下面就来... 目录一、问题原因分析二、解决方案1. 以 root 权限运行 Nginx(不推荐)2. 为 Nginx

解决1093 - You can‘t specify target table报错问题及原因分析

《解决1093-Youcan‘tspecifytargettable报错问题及原因分析》MySQL1093错误因UPDATE/DELETE语句的FROM子句直接引用目标表或嵌套子查询导致,... 目录报js错原因分析具体原因解决办法方法一:使用临时表方法二:使用JOIN方法三:使用EXISTS示例总结报错原