贪心算法-最大数

题目:https://leetcode.cn/problems/largest-number/description/

「最大数」问题知识点总结


一、题目核心要求

  • 给定一组非负整数,不可拆分单个数字 ,重新排列顺序,拼接成一个最大的整数
  • 因结果可能极大,需返回字符串而非整数。
  • 示例:
    • 输入 [10,2] → 输出 "210"(因为 "2"+"10" > "10"+"2"
    • 输入 [3,30,34,5,9] → 输出 "9534330"

二、算法核心原理

1. 排序的本质

排序的核心是确定元素的先后顺序,即判断任意两个元素谁在前、谁在后能让整体结果更优。

2. 普通排序的局限性

普通升序/降序的比较逻辑(直接比较数字大小)不满足本题需求,因为其比较规则不具备传递性,会出现逻辑矛盾(如示例中直接比较数字大小无法得到正确顺序)。

3. 本题的排序优化思路
  • 关键转换 :将所有数字转为字符串,通过拼接后的字典序比较来确定顺序。
  • 排序规则 :对两个字符串 ab,比较 a + bb + a 的字典序:
    • a + b > b + aa 放在 b 前面
    • a + b < b + ab 放在 a 前面
  • 该规则满足传递性,可保证整体排序后拼接出最大数。

三、边界处理

  • 若输入全为0(如 [0,0]),需输出 "0" 而非 "00",避免无效前导零。

四、核心思想提炼

本题的核心是自定义排序规则,通过字符串拼接比较替代普通数字比较,从而得到全局最优的排列顺序。

相关推荐
一叶落4383 小时前
LeetCode 219. 存在重复元素 II(C语言详解)
算法·哈希算法·散列表
像污秽一样3 小时前
算法设计与分析-习题2.4
数据结构·算法·排序算法
不想看见4043 小时前
Reverse Bits位运算基础问题--力扣101算法题解笔记
笔记·算法·leetcode
罗湖老棍子3 小时前
【例 2】数星星 Stars(信息学奥赛一本通- P1536)
数据结构·算法·树状数组·单点修改 区间查询
逆境不可逃4 小时前
LeetCode 热题 100 之 394. 字符串解码 739. 每日温度 84. 柱状图中的最大矩形
算法·leetcode·职场和发展
重生之后端学习4 小时前
62. 不同路径
开发语言·数据结构·算法·leetcode·职场和发展·深度优先
小资同学4 小时前
考研机试 -Kruskal算法
算法
big_rabbit05024 小时前
[算法][力扣283]Move Zeros
算法·leetcode·职场和发展
小资同学4 小时前
考研机试动态规划 线性DP
算法·动态规划
listhi5204 小时前
两台三相逆变器并联功率分配控制MATLAB实现
算法