【Day27】LeetCode:56. 合并区间,738. 单调递增的数字

文章目录

  • [LeetCode:56. 合并区间](#LeetCode:56. 合并区间)
  • [LeetCode:738. 单调递增的数字](#LeetCode:738. 单调递增的数字)

LeetCode:56. 合并区间

https://leetcode.cn/problems/merge-intervals/

思路

  1. 按区间左端点升序排序 intervals
  2. 用区间 [last_start, last_end] 记录上一个正在合并的区间。然后遍历数组:
    (1)如果当前区间和正在合并的区间重叠:如果完全重叠就直接跳过;如果没有完全重叠,则更新正在合并的区间为 [last_start, end]
    (2)如果当前区间和正在的合并的区间不重叠:则说明上一个正在合并的区间可以合并结束,将合并后的区间加入结果,然后将当前区间作为正在合并的区间。
  3. 最后将最后一个正在合并的区间添加进结果。

解答

python 复制代码
class Solution:
    def merge(self, intervals: List[List[int]]) -> List[List[int]]:
        n = len(intervals)
        intervals.sort(key=lambda x: x[0]) # 按区间左端点升序排序
        results = []

        last_start = intervals[0][0]
        last_end = intervals[0][1]

        for index, interval in enumerate(intervals[1:]):
            start = interval[0]
            end = interval[1]

            if start <= last_end and end > last_end: # 重叠且不完全覆盖
                    last_end = end
            elif start > last_end: # 完全不重叠,插入上一个
                results.append([last_start, last_end])
                last_start = start
                last_end = end
        
        results.append([last_start, last_end]) # 插入最后一个
        
        return results

LeetCode:738. 单调递增的数字

https://leetcode.cn/problems/monotone-increasing-digits/description/

思路

倒序遍历数组,如果 nums[i-1] > nums[i] ,即出现递减,则标记 flag = i ,使得其后所有数都为9,然后 nums[i-1]-- 。(例如出现 324 ,因为 3 > 2 ,所以标记数字 2 ,前一位 - 1,得到 299)。

解答

python 复制代码
class Solution:
    def monotoneIncreasingDigits(self, n: int) -> int:
        nums = list(str(n))

        flag = len(nums) # 标记从哪一位开始后面都是9

        for i in range(len(nums) - 1, 0, -1): # 倒序遍历
            if nums[i-1] > nums[i]:
                flag = i
                nums[i-1] = str(int(nums[i-1]) - 1)
        
        for i in range(flag, len(nums)):
            nums[i] = '9'

        return int("".join(nums))
相关推荐
Boop_wu2 小时前
[Java 算法] 模拟
算法
叶子2024222 小时前
承认错误才能成长
python
khddvbe2 小时前
C++中的代理模式实战
开发语言·c++·算法
计算机安禾2 小时前
【C语言程序设计】第31篇:指针与函数
c语言·开发语言·数据结构·c++·算法·leetcode·visual studio
Frostnova丶2 小时前
LeetCode 3070. 元素和小于等于 k 的子矩阵数目
算法·leetcode·矩阵
郝学胜-神的一滴2 小时前
算法奇旅:探寻3/5/7素因子之第k特殊数——优雅的多路指针解法全解析
数据结构·c++·算法·职场和发展
handler012 小时前
基础算法:分治
c语言·开发语言·c++·笔记·学习·算法·深度优先
Yzzz-F3 小时前
Problem - D2 - Codeforces [插入计数]
算法
图图的点云库3 小时前
点云深度学习算法概述
人工智能·深度学习·算法