[贪心算法]-最大数(lambda 表达式的补充)

1.解析

我们一般使用的排序比较大小都是

a>b 那么a在b的前面

a=b 无所谓

a<b a在b的后面

本题的排序则是

ab>ba 那么a在b的前面

ab=ba 无所谓

ab<ba a在b的后面

2.代码

cpp 复制代码
class Solution {
public:
    string largestNumber(vector<int>& nums) {
        //1.先把所有的数字转成string
        //2.对sort这个排序进行转化
        //3.提取结果
        //特殊处理:如果第一个位置为0,那这个字符串就是全0
        vector<string> strs;
        for(int num:nums)
        {
            strs.push_back(to_string(num));
        }
        sort(strs.begin(),strs.end(),[](const string &s1,const string &s2)
        {
            return s1+s2>s2+s1;
        });
        
        string ret;
        for(auto& s:strs)
        {
            ret+=s;
        }
        if(ret[0]=='0') return "0";
        return ret;
    }
};

补充语法:lambda 表达式

capture_list\] (parameters) -\> return_type { function_body }

  • capture_list:捕获列表,捕获外部作用域的变量,可以为空

  • parameters:参数列表,和正常的函数一样

    剩下的就是返回值类型(C++14之后可以省略,会自动推导),和函数主体,第一次看感觉这个东西的写法有点奇怪,在上面的代码中就是sort的一个参数。

相关推荐
草履虫建模4 小时前
力扣算法 1768. 交替合并字符串
java·开发语言·算法·leetcode·职场和发展·idea·基础
naruto_lnq6 小时前
分布式系统安全通信
开发语言·c++·算法
Jasmine_llq7 小时前
《P3157 [CQOI2011] 动态逆序对》
算法·cdq 分治·动态问题静态化+双向偏序统计·树状数组(高效统计元素大小关系·排序算法(预处理偏序和时间戳)·前缀和(合并单个贡献为总逆序对·动态问题静态化
爱吃rabbit的mq7 小时前
第09章:随机森林:集成学习的威力
算法·随机森林·集成学习
(❁´◡`❁)Jimmy(❁´◡`❁)8 小时前
Exgcd 学习笔记
笔记·学习·算法
YYuCChi8 小时前
代码随想录算法训练营第三十七天 | 52.携带研究材料(卡码网)、518.零钱兑换||、377.组合总和IV、57.爬楼梯(卡码网)
算法·动态规划
不能隔夜的咖喱9 小时前
牛客网刷题(2)
java·开发语言·算法
VT.馒头9 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript
进击的小头9 小时前
实战案例:51单片机低功耗场景下的简易滤波实现
c语言·单片机·算法·51单片机
咖丨喱11 小时前
IP校验和算法解析与实现
网络·tcp/ip·算法