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

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

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

相关推荐

06-10 21:15
门头沟学院 Java
宁阿:好多这种没🧠的公司,他们估计都不知道毕业的人不能给安排实习岗
实习吐槽大会
点赞 评论 收藏
分享
点赞 评论 收藏
分享
07-02 13:50
闽江学院 Java
点赞 评论 收藏
分享
评论
4
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务