贪心算法435|763|56

435无重叠区间

class Solution:
    def eraseOverlapIntervals(self, intervals: List[List[int]]) -> int:
        if len(intervals) == 1:
            return 0
        count = 0
        sorted_intervals = sorted(intervals, key = lambda x: x[0])
        for i in range(1, len(sorted_intervals)):
            if sorted_intervals[i][0] < sorted_intervals[i - 1][1]:
                count += 1
                sorted_intervals[i][1] = min(sorted_intervals[i][1], sorted_intervals[i - 1][1])
        return count

763划分字母区间

class Solution:
    def partitionLabels(self, s: str) -> List[int]:
        count = [0] * 26
        for i in range(len(s)):
            cur = s[i]
            count[ord(cur) - ord("a")] = i
        left = 0
        right = 0
        result = []
        for i in range(len(s)):
            cur = s[i]
            index = ord(cur) - ord("a")
            if right < count[index]:
                right = count[index]
            if right == i:
                result.append(right - left + 1)
                left = right + 1
        return result

56合并区间

class Solution:
    def merge(self, intervals: List[List[int]]) -> List[List[int]]:
        if len(intervals) == 1:
            return intervals
        result = []
        sorted_intervals = sorted(intervals, key = lambda x: x[0])
        result.append(sorted_intervals[0])
        for i in range(1, len(sorted_intervals)):
            if sorted_intervals[i][0] <= result[-1][1]:
                result[-1][1] = max(sorted_intervals[i][1], result[-1][1])
            else:
                result.append(sorted_intervals[i])
        return result

全部评论

相关推荐

半解316:内容充实,细节需要修改一下。 1,整体压缩为一页。所有内容顶格。 2,项目描述删除,直接写个人工作量 修改完之后还需要建议,可以私聊
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-01 17:13
想去,但是听说加班强度实在难崩,所以拒绝了,现在有点心梗对面hr感觉也是实习生,打电话的时候怪紧张的,但是感觉人很好嘞
水中水之下水道的鼠鼠:哥们这不先去体验一下,不行再跑呗,大不了混个实习经历(有更好的转正offer就当我没说)
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务