前言

我们社区陆续会将顾毅(Netflix 增长黑客,《iOS 面试之道》作者,ACE 职业健身教练。)的 Swift 算法题题解整理为文字版以方便大家学习与阅读。

LeetCode 算法到目前我们已经更新到 171 期,我们会保持更新时间和进度(周一、周三、周五早上 9:00 发布),每期的内容不多,我们希望大家可以在上班路上阅读,长久积累会有很大提升。

不积跬步,无以至千里;不积小流,无以成江海,Swift社区 伴你前行。如果大家有建议和意见欢迎在文末留言,我们会尽力满足大家的需求。

难度水平:中等

1. 描述

给定一组非负整数 ​​nums​​,重新排列每个数的顺序(每个数不可拆分)使之组成一个最大的整数。

注意: 输出结果可能非常大,所以你需要返回一个字符串而不是整数。

2. 示例

示例 1

输入:nums = [10,2]
输出:"210"

示例 2

输入:nums = [3,30,34,5,9]
输出:"9534330"

约束条件:

  • ​1 <= nums.length <= 100​
  • ​0 <= nums[i] <= 10^9​

进阶:

  • 你可以设计一个满足下述条件的解决方案吗?​​next()​​​ 和​​hasNext()​​​ 操作均摊时间复杂度为​​O(1)​​​ ,并使用​​O(h)​​​ 内存。其中​​h​​ 是树的高度。

3. 答案

class Solution {
func largestNumber(_ A: [Int]) -> String {
let result = A.map { "\($0)" }.sorted(by: { $0 + $1 > $1 + $0 }).joined()
return result.first == "0" ? "0"
  • 主要思想:就地映射并排序数组以形成最大的数。
  • 时间复杂度: O(nlogn)
  • 空间复杂度: O(1)

该算法题解的仓库:​​LeetCode-Swift​