c++自定義排序_lambda表達式

class Solution {
    void quickSort(vector<string>& 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<int>& nums) {
        vector<string> 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<int>& nums) {
        vector<string> 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;
    }
};
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章