179. 最大数

Problem: 179. 最大数

文章目录

思路

自定义排序,将字符串大的拼接到前面

复杂度

时间复杂度: O ( n l o g n , n ) O(nlogn, n) O(nlogn,n) = O ( n l o g n ) O(nlogn) O(nlogn) 排序和数组字符串化

空间复杂度: O ( n ) O(n) O(n) 字符串列表的空间

Code

Python3 复制代码
import functools

class Solution:
    def largestNumber(self, nums: List[int]) -> str:
        nums = list(map(str, nums))
        
        # 自定义排序关系
        def cmp(a, b):
            if a + b == b + a: # a = b的关系
                return 0
            if a + b > b + a: # a > b的关系
                return 1 
            else: # a < b的关系
                return -1
        nums.sort(key=functools.cmp_to_key(cmp), reverse=True)
        return ''.join(nums) if nums[0] != '0' else '0'
相关推荐
今天又在写代码20 分钟前
数据结构v2
数据结构
加农炮手Jinx30 分钟前
LeetCode 146. LRU Cache 题解
算法·leetcode·力扣
Rabitebla31 分钟前
C++ 和 C 语言实现 Stack 对比
c语言·数据结构·c++·算法·排序算法
加农炮手Jinx31 分钟前
LeetCode 128. Longest Consecutive Sequence 题解
算法·leetcode·力扣
旖-旎32 分钟前
递归(汉诺塔问题)(1)
c++·学习·算法·leetcode·深度优先·递归
深邃-33 分钟前
【数据结构与算法】-顺序表链表经典算法
java·c语言·数据结构·c++·算法·链表·html5
努力学习的小廉34 分钟前
我爱学算法之—— 前缀和(上)
c++·算法
JAVA学习通34 分钟前
励志从零打造LeetCode平台之C端竞赛列表
java·vscode·leetcode·docker·状态模式
AC178034 分钟前
深入浅出 PID 算法:原理、实现与应用实战
人工智能·算法·机器学习
就爱学编程34 分钟前
惊叹数据结构之美,品味排序算法之妙:对计排、桶排的详细介绍
数据结构·算法·排序算法