【算法详解】力扣179.最大数

一、题目描述

力扣链接:力扣179.最大数

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

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

示例 1:

输入:nums = [10,2]

输出:"210"

二、C++题解

可使用贪心策略,只要每一步都保证是最大的,那么最后拼接出来的数字一定是最大的。

有两个推论:

  • 两个数字拼接,若x+y > y+x,则拼接时x应在前;
  • 反之,y应该在前。

因此,算法流程为:

  • 初始化: 字符串列表 strs ,保存各数字的字符串格式。
  • 列表排序: 根据贪心策略对 strs 进行从大到小排序。
  • 返回值: 拼接 strs中的所有字符串,并返回。
cpp 复制代码
class Solution {
public:
    string largestNumber(vector<int>& nums) {
        vector<string> strs;
        string result;
        if (nums.empty()) {
            return result;
        }

        // 把所有数字转为字符串并存储为数组
        for (auto& num : nums) {
            strs.push_back(to_string(num));
        }

        // 按从大到小排序
        sort(strs.begin(), strs.end(), [](string& x, string& y){
            return x + y > y + x;
        });

        // 如果排完最大的是0,那么直接输出0,避免输出"000..."
        if (strs[0] == "0") {
            return "0";
        }

        // 直接将数组中的字符串拼接起来
        for (auto& str : strs) {
            result.append(str);
        }

        return result;
    }
};
相关推荐
风中的微尘24 分钟前
39.网络流入门
开发语言·网络·c++·算法
西红柿维生素1 小时前
JVM相关总结
java·jvm·算法
ChillJavaGuy3 小时前
常见限流算法详解与对比
java·算法·限流算法
sali-tec3 小时前
C# 基于halcon的视觉工作流-章34-环状测量
开发语言·图像处理·算法·计算机视觉·c#
你怎么知道我是队长4 小时前
C语言---循环结构
c语言·开发语言·算法
艾醒4 小时前
大模型面试题剖析:RAG中的文本分割策略
人工智能·算法
纪元A梦7 小时前
贪心算法应用:K-Means++初始化详解
算法·贪心算法·kmeans
_不会dp不改名_7 小时前
leetcode_21 合并两个有序链表
算法·leetcode·链表
mark-puls7 小时前
C语言打印爱心
c语言·开发语言·算法
Python技术极客7 小时前
将 Python 应用打包成 exe 软件,仅需一行代码搞定!
算法