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)。