牛客题霸--拼接所有的字符串产生字典序最小的字符串

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

https://www.nowcoder.com/practice/f1f6a1a1b6f6409b944f869dc8fd3381?tpId=117&&tqId=35274&rp=1&ru=/ta/job-code-high&qru=/ta/job-code-high/question-ranking

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

题目链接

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;
    }
};
全部评论

相关推荐

勇敢的联想人前程似锦:如果我是你,身体素质好我会去参军,然后走士兵计划考研211只需要200多分。
点赞 评论 收藏
分享
4 收藏 评论
分享
牛客网
牛客企业服务