Leetcode179. 最大数

Every day a Leetcode

题目来源:179. 最大数

解法1:贪心

对于数组 nums 中的任意两个数 a 和 b,我们将其转换为字符串后,如果 to_string(a) + to_string(b) > to_string(b) + to_string(a),说明 a 应该放在 b 的前面,这样拼接成的数字更大。

注意特判全为 0 的情况,这样会拼接出类似于 "0...00" 的字符串,应该只返回 "0"。

代码:

c 复制代码
/*
 * @lc app=leetcode.cn id=179 lang=cpp
 *
 * [179] 最大数
 */

// @lc code=start
class Solution
{
private:
    static bool cmp(const int &a, const int &b)
    {
        return to_string(a) + to_string(b) > to_string(b) + to_string(a);
    }

public:
    string largestNumber(vector<int> &nums)
    {
        int n = nums.size();
        sort(nums.begin(), nums.end(), cmp);
        string ans;
        for (const int &num : nums)
            ans += to_string(num);
        return ans[0] == '0' ? "0" : ans;
    }
};
// @lc code=end

结果:

复杂度分析:

时间复杂度:O(nlogn),其中 n 是数字 nums 的元素个数。

空间复杂度:O(1)。

相关推荐
hrrrrb几秒前
【算法设计与分析】随机化算法
人工智能·python·算法
进击的小头7 分钟前
一阶IIR低通滤波器:从原理到嵌入式实战
c语言·算法
五_谷_丰_登7 分钟前
C++模板元编程学习——模板简介
c++·stl·c++标准库
2301_8112329820 分钟前
C++中的契约编程
开发语言·c++·算法
2401_8290040221 分钟前
C++中的访问者模式
开发语言·c++·算法
D_evil__27 分钟前
【Effective Modern C++】第三章 转向现代C++:13. 优先选用const_iterator,而非iterator
c++
青槿吖28 分钟前
第二篇:JDBC进阶骚操作:防注入、事务回滚、连接池优化,一篇封神
java·开发语言·jvm·算法·自动化
sin_hielo28 分钟前
leetcode 1984
数据结构·算法·leetcode
赵萱婷29 分钟前
C++17 nodiscard属性深度解析
开发语言·c++·经验分享