day27-数据结构力扣

56. 合并区间

题目描述56. 合并区间 - 力扣(LeetCode)

思路

这道题的核心是先排序,再合并,通过排序让重叠 / 相邻的区间挨在一起,再遍历一次就能完成合并。

解题思路

  1. 特殊情况处理:如果输入数组为空,直接返回空数组。

  2. 排序 :按照区间的起始值从小到大排序,这样所有可能重叠的区间都会相邻。

  3. 遍历合并

    • 初始化结果数组,放入第一个区间。

    • 遍历后续每个区间,与结果数组中最后一个区间比较:

      • 如果当前区间的起始值 ≤ 最后一个区间的结束值 → 重叠 / 相邻,合并(更新结束值为两者最大值)。

      • 如果当前区间的起始值 > 最后一个区间的结束值 → 不重叠,直接加入结果数组。

提交

python 复制代码
def merge(intervals):
    # 1. 处理空数组
    if not intervals:
        return []
    
    # 2. 按照区间的起始值排序
    intervals.sort(key=lambda x: x[0])
    
    # 3. 初始化结果数组,放入第一个区间
    res = [intervals[0]]
    
    # 4. 遍历剩余区间
    for current in intervals[1:]:
        # 取出结果数组中最后一个区间
        last = res[-1]
        # 判断是否重叠/相邻:当前区间起始 <= 最后一个区间的结束
        if current[0] <= last[1]:
            # 合并区间:更新结束值为最大值
            last[1] = max(last[1], current[1])
        else:
            # 不重叠,直接添加
            res.append(current)
    
    return res

738.单调递增的数字

题目链接738. 单调递增的数字 - 力扣(LeetCode)

思路

这道题的核心是用贪心算法 :从右往左检查数字,遇到前一位 > 后一位时,前一位减 1,后面所有位都变成 9,就能得到最大的单调递增数。

解题思路

  1. 转字符串 / 列表:方便逐位修改数字(整数无法直接修改某一位)。

  2. 从右往左遍历

    • 如果当前位 < 前一位(不满足递增),前一位减 1,记录当前位置。

    • 记录位置及后面所有位都设为 9(保证最大)。

  3. 转回整数:得到最终结果。

提交

python 复制代码
def monotoneIncreasingDigits(n: int) -> int:
    s = list(str(n))
    length = len(s)
    nine_start = length

    # 从右往左遍历
    for i in range(length - 2, -1, -1):
        if s[i] > s[i + 1]:
            s[i] = str(int(s[i]) - 1)
            nine_start = i + 1

    # 统一变成 字符串 '9',这是关键!
    for i in range(nine_start, length):
        s[i] = '9'  # 必须是字符串,不是数字

    return int(''.join(s))
相关推荐
01_ice19 小时前
C语言复杂度
数据结构
05候补工程师19 小时前
【408高分笔记】数据结构冲刺:二叉树遍历性质、特殊形态与栈的跨界联动秒杀技巧
数据结构·经验分享·笔记·考研·算法
菜菜的顾清寒19 小时前
力扣HOT100(36)二分查找-搜索插入位置
数据结构·算法·leetcode
Dlrb121119 小时前
数据结构-树与二叉树
数据结构·二叉树·深度优先··广度优先·层序遍历
Chen_harmony19 小时前
二十二、动态内存管理
c语言·数据结构·算法
孬甭_20 小时前
栈和队列
c语言·数据结构
周末也要写八哥20 小时前
经典算法题之删列造序(二)
数据结构·算法
枕星而眠21 小时前
数据结构八大排序详解(二):四大高阶排序(归并/快排/堆/基数)
数据结构
LuminousCPP21 小时前
C 语言通讯录补坑篇:终版遗留 Bug 修复,解决修改姓名输入错乱问题
c语言·开发语言·数据结构·经验分享·笔记·顺序表
z落落21 小时前
C# 数组高阶函数(Find/FindAll/Exists/ForEach/All/Any)
javascript·数据结构·算法