拼接所有的字符串产生字典序最小的字符串

题目链接

Solution

是拼接后的字符串字典序最小。
根据贪心的思路,字典序小的放在前面比较优秀。比如"abc"放到"bca"的前面更好。
但是这样有个问题,就是字符串长度的问题,比如"bc""bca"此时应该将字典序大的"bca"放到前面。
为了解决此问题,不能直接按字典序排序,但是我们可以按照两个字符串连起来后的字符串的字典序排序。
比如"bc""bca",比较"bcbca"和"bcabc"那个字典序小,来确定"bc""bca"的位置。

Code

class Solution {
public:
    static bool cmp(const string a, const string b) {
        return (a + b) < (b + a);
    }
    string minString(vector<string>& strs) {
        string ans;
        sort(strs.begin(), strs.end(), cmp);
        for (int i = 0; i < (int)strs.size(); ++i) ans += strs[i];
        return ans;
    }
};