栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

c++自定义排序

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

c++自定义排序

class Solution {
    void quickSort(vector& strs, int l, int r)
    {
        if (l >= r) return;
        int i = l, j = r;
        while (i < j)
        {
            while(strs[j] + strs[l] >= strs[l] + strs[j] && i < j) j--;
            while(strs[i] + strs[l] <= strs[l] + strs[i] && i < j ) i++;
            swap(strs[i], strs[j]);
        } 
        swap(strs[l], strs[i]);
        quickSort(strs, l, i - 1);
        quickSort(strs, i + 1, r);
    }
public:
    string minNumber(vector& nums) {
        vector strs;
        for (const auto & e : nums) {
            strs.push_back(to_string(e));
        }
        quickSort(strs, 0, strs.size() - 1);
        string res;
        for(string s : strs) {
            res.append(s);
        }
        return res;
    }
};
class Solution {
public:
    string minNumber(vector& nums) {
        vector strs;
        for (const auto & e : nums) {
            strs.push_back(to_string(e));
        }
        // quickSort(strs, 0, strs.size() - 1);
        sort(strs.begin(), strs.end(), [](string& x, string& y) { return x + y < y + x; });
        string res;
        for(string s : strs) {
            res.append(s);
        }
        return res;
    }
};
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/869119.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号