牛客题霸--拼接所有的字符串产生字典序最小的字符串
拼接所有的字符串产生字典序最小的字符串
题目链接
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;
}
};