代码随想录算法训练营第三十六天丨435. 无重叠区间、763. 划分字母区间、56. 合并区间

本文主要是介绍代码随想录算法训练营第三十六天丨435. 无重叠区间、763. 划分字母区间、56. 合并区间,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

435. 无重叠区间

我的思路:

跟昨天的第三题很像,按照右边界排序,记录当前非重叠区间的右边界用于检测下个区间起点,由于区间按照右边界有序,非重叠区域右界必定是判断过的最小值;迭代结束即可得到结果。

class Solution:def eraseOverlapIntervals(self, intervals: List[List[int]]) -> int:intervals.sort(key=lambda x: x[1])start = intervals[0][1]res = 0for interval in intervals[1:]:if interval[0] < start:res += 1else:start = interval[1]return res

优化思路:

可以只判断一次,记录非重叠区域数量。

class Solution:def eraseOverlapIntervals(self, intervals: List[List[int]]) -> int:intervals.sort(key=lambda x: x[1])start = intervals[0][1]count = 1for interval in intervals[1:]:if interval[0] >= start:count +=1start = interval[1]return len(intervals) - count

763. 划分字母区间

我的思路:

遍历一次字符串,记录每个字符最后一次出现的位置。遍历字符串,对于每个字符,更新当前片段的结束位置 end 为当前字符的最后出现位置。如果当前位置达到了 end,说明当前片段结束,记录当前片段的长度,并将 start 更新为 end,表示开始下一个片段。

class Solution:def partitionLabels(self, s: str) -> List[int]:n = len(s)last_pos = collections.defaultdict()for i, char in enumerate(s):last_pos[char] = ires = []i = 0start = 0while i < n:end = last_pos[s[i]] + 1while i < end:if last_pos[s[i]] + 1 > end:end = last_pos[s[i]] + 1i += 1res.append(end - start)start = endreturn res

优化:

代码量有点大,其实可以直接写for循环。

import collectionsclass Solution:def partitionLabels(self, s: str) -> List[int]:n = len(s)last_pos = collections.defaultdict(int)for i, char in enumerate(s):last_pos[char] = ires = []start = 0end = 0for i in range(n):end = max(end, last_pos[s[i]])if i == end:res.append(end - start + 1)start = i + 1return res

可以用数组做哈希,这里不再改写了...

56. 合并区间

我的思路:

ac了,但是思路有点问题,我一开始想的是对右边界排序;改成左边界直接AC了,并没有能想明白。

初始化左边界和右边界为第一个interval。遍历剩下的interval,如果遇到不相交的,把当前的左右边界作为结果记录;如果相交,更新左右边界。

class Solution:def merge(self, intervals: List[List[int]]) -> List[List[int]]:intervals.sort()cur_left,cur_right = intervals[0][0], intervals[0][1]res = []for interval in intervals[1:]:if interval[0] > cur_right:res.append([cur_left, cur_right])cur_left, cur_right = interval[0], interval[1]else:cur_left = min(cur_left, interval[0])cur_right = max(cur_right, interval[1])res.append([cur_left, cur_right])return res

仔细研究了一下,还是没能正确理解排序的作用,其实左边界已经有序了,左边界直接加入结果,如果有重叠直接更新右边界就可以了。

class Solution:def merge(self, intervals: List[List[int]]) -> List[List[int]]:intervals.sort()res = []for interval in intervals:if not res or interval[0] > res[-1][1]:res.append(interval)else:res[-1][1] = max(res[-1][1], interval[1])return res

这个就是题解方法了!

如果对右边界排序,则需要从后向前遍历,因为右边界有序,从后遍历右边界一定是更大的。

class Solution:def merge(self, intervals: List[List[int]]) -> List[List[int]]:intervals.sort(key=lambda x: x[1])  # 按照右边界排序res = []while intervals:cur_left, cur_right = intervals.pop()while intervals and intervals[-1][1] >= cur_left:cur_left = min(cur_left, intervals[-1][0])intervals.pop()res.append([cur_left, cur_right])return res

这篇关于代码随想录算法训练营第三十六天丨435. 无重叠区间、763. 划分字母区间、56. 合并区间的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

vscode保存代码时自动eslint格式化图文教程

《vscode保存代码时自动eslint格式化图文教程》:本文主要介绍vscode保存代码时自动eslint格式化的相关资料,包括打开设置文件并复制特定内容,文中通过代码介绍的非常详细,需要的朋友... 目录1、点击设置2、选择远程--->点击右上角打开设置3、会弹出settings.json文件,将以下内

SQL Server使用SELECT INTO实现表备份的代码示例

《SQLServer使用SELECTINTO实现表备份的代码示例》在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误,在SQLServer中,可以使用SELECTINT... 在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误。在 SQL Server 中,可以使用 SE

使用Python合并 Excel单元格指定行列或单元格范围

《使用Python合并Excel单元格指定行列或单元格范围》合并Excel单元格是Excel数据处理和表格设计中的一项常用操作,本文将介绍如何通过Python合并Excel中的指定行列或单... 目录python Excel库安装Python合并Excel 中的指定行Python合并Excel 中的指定列P

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一

在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码

《在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码》在MyBatis的XML映射文件中,trim元素用于动态添加SQL语句的一部分,处理前缀、后缀及多余的逗号或连接符,示... 在MyBATis的XML映射文件中,<trim>元素用于动态地添加SQL语句的一部分,例如SET或W

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

基于C#实现PDF文件合并工具

《基于C#实现PDF文件合并工具》这篇文章主要为大家详细介绍了如何基于C#实现一个简单的PDF文件合并工具,文中的示例代码简洁易懂,有需要的小伙伴可以跟随小编一起学习一下... 界面主要用于发票PDF文件的合并。经常出差要报销的很有用。代码using System;using System.Col

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

Python视频剪辑合并操作的实现示例

《Python视频剪辑合并操作的实现示例》很多人在创作视频时都需要进行剪辑,本文主要介绍了Python视频剪辑合并操作的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录介绍安装FFmpegWindowsMACOS安装MoviePy剪切视频合并视频转换视频结论介绍

python多进程实现数据共享的示例代码

《python多进程实现数据共享的示例代码》本文介绍了Python中多进程实现数据共享的方法,包括使用multiprocessing模块和manager模块这两种方法,具有一定的参考价值,感兴趣的可以... 目录背景进程、进程创建进程间通信 进程间共享数据共享list实践背景 安卓ui自动化框架,使用的是