leetcode原题: 最大数

题目:

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

**注意:**输出结果可能非常大

所以你需要返回一个字符串而不是整数。

示例1:

输入:nums = [10,2]

输出:"210"

示例2:

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

输出:"9534330"

解题思路:

首先,如果要组成最大的数,就要将数字首位数值最大的数排在前面,这里分为两种情况,首位数值不同、首位数值相同。首位数值不同,很好解决,数值大的放在前面即可,但是首位数值相同的话,我们不能直接确定大小。

例如[4,45] 可以组成445,454,454更大

但是[3,32] 组成332,323 ,332更大

所以我们需要将所有情况列出来,进行比较,才能知道哪种情况为最大值。

这里我们用到了lamda表达式来解决排序问题。

排序后,将数组放进一个字符串里即可。

最后返回是,如果字符串首字符为'0',那么我们返回字符串"0",否则按正常情况处理。

Code:

cpp 复制代码
class Solution {
public:
    string largestNumber(vector<int>& nums) {
        //先将数组转成字符串
        vector<string> str;
        for(auto i:nums)
        {
            str.push_back(to_string(i));
        }
        //对字符串数组进行排序,这里使用lamda表达式来实现排序
        //例如[4,45] 要比较445和454的大小,按数值大的在前进行排序
        sort(str.begin(),str.end(),[](const auto& A,const auto& B){
            return A+B>B+A;
        });
        //将字符串数组中的字符串放入到一个字符串中
        string ans;
        for(const auto& a:str)
        {
            ans+=a;
        }
        //如果字符串的首字符为'0',直接返回字符串"0"
        return ans[0]=='0'?"0":ans;
    }
};
相关推荐
Trouvaille ~17 分钟前
【C++篇】C++类与对象深度解析(六):全面剖析拷贝省略、RVO、NRVO优化策略
c++·c++20·编译原理·编译器·类和对象·rvo·nrvo
little redcap18 分钟前
第十九次CCF计算机软件能力认证-乔乔和牛牛逛超市
数据结构·c++·算法
机器视觉知识推荐、就业指导1 小时前
Qt/C++事件过滤器与控件响应重写的使用、场景的不同
开发语言·数据库·c++·qt
muyierfly1 小时前
34.贪心算法1
算法·贪心算法
孤寂大仙v1 小时前
【C++】STL----list常见用法
开发语言·c++·list
咩咩大主教2 小时前
C++基于select和epoll的TCP服务器
linux·服务器·c语言·开发语言·c++·tcp/ip·io多路复用
luthane3 小时前
python 实现average mean平均数算法
开发语言·python·算法
静心问道3 小时前
WGAN算法
深度学习·算法·机器学习
Ylucius3 小时前
动态语言? 静态语言? ------区别何在?java,js,c,c++,python分给是静态or动态语言?
java·c语言·javascript·c++·python·学习
是店小二呀4 小时前
【C++】C++ STL探索:Priority Queue与仿函数的深入解析
开发语言·c++·后端