贪心算法-最大数

题目: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",避免无效前导零。

四、核心思想提炼

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

相关推荐
吃好睡好便好8 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
仰泳之鹅8 小时前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
x_yeyue11 小时前
三角形数
笔记·算法·数论·组合数学
念何架构之路12 小时前
Go语言加密算法
数据结构·算法·哈希算法
AI科技星12 小时前
《数学公理体系·第三部·数术几何》(2026 年版)
c语言·开发语言·线性代数·算法·矩阵·量子计算·agi
失去的青春---夕阳下的奔跑12 小时前
560. 和为 K 的子数组
数据结构·算法·leetcode
黎阳之光12 小时前
黎阳之光:以视频孪生重构智慧医院信息化,打造高标项目核心竞争力
大数据·人工智能·物联网·算法·数字孪生
丷丩13 小时前
三级缓存下MVT地图瓦片服务性能优化策略
算法·缓存·性能优化·gis·geoai-up
m0_6294947313 小时前
LeetCode 热题 100-----25.回文链表
数据结构·算法·leetcode·链表
ʚ希希ɞ ྀ14 小时前
单词拆分----dp
算法