算法题day38(补5.24日卡:贪心算法day5)

一、刷题:

1.leetcode题目 435. 无重叠区间 - 力扣(LeetCode)(medium)

解决:

python 复制代码
class Solution:
    def eraseOverlapIntervals(self, intervals: List[List[int]]) -> int:
        intervals.sort(key = lambda x:(x[0],x[1]))
        ans = 0
        for i in range(1,len(intervals)):
            if intervals[i][0]<intervals[i-1][1]:
                ans += 1
                intervals[i][1] = min(intervals[i-1][1],intervals[i][1])

        return ans
            

2.leetcode题目 763. 划分字母区间 - 力扣(LeetCode)(medium)

解决:

python 复制代码
class Solution:
    def partitionLabels(self, s: str) -> List[int]:
        last = {}
        for i,ch in enumerate(s):
            last[ch] = i
        start =0
        ans = []
        end = 0
        for i,ch in enumerate(s):
            end = max(end,last[ch])
            if i==end:
                length = end-start+1
                ans.append(length)
                start = i+1
        return ans

3.leetcode题目 56. 合并区间 - 力扣(LeetCode)(medium)

解决:

python 复制代码
class Solution:
    def merge(self, intervals: List[List[int]]) -> List[List[int]]:
        intervals.sort(key = lambda x:(x[0],x[1]))
        ans = [intervals[0]]
        for i in range(1,len(intervals)):
            if intervals[i][0] <= intervals[i-1][1]:
                ans[-1] = [intervals[i-1][0],max(intervals[i][1],intervals[i-1][1])]
                intervals[i] = [intervals[i-1][0],max(intervals[i][1],intervals[i-1][1])]
            else:
                ans.append(intervals[i])
        return ans
相关推荐
hoiii1871 小时前
孤立森林 (Isolation Forest) 快速异常检测系统
算法
c++之路2 小时前
适配器模式(Adapter Pattern)
java·算法·适配器模式
吴声子夜歌3 小时前
Java——接口的细节
java·开发语言·算法
myheartgo-on3 小时前
Java—方 法
java·开发语言·算法·青少年编程
汉克老师4 小时前
GESP6级C++考试语法知识(四、图与树(四))
c++·贪心算法·优先队列·哈夫曼编码·哈夫曼树·gesp6级·gesp六级
宝贝儿好4 小时前
【LLM】第三章:项目实操案例:智能输入法项目
人工智能·python·深度学习·算法·机器人
雪碧聊技术5 小时前
上午题_算法
算法·软考·软件设计师
naturerun5 小时前
从数组中删除元素的算法
数据结构·c++·算法
斯内科6 小时前
四胞胎素数:找出‌个位数分别是 1、3、7、9‌,且‌十位及更高位数字完全相同‌的质数,例如 11、13、17、19
算法·质数·素数·四胞胎素数