题目大意
此题就是将输入的若干个数拼接在一起,求何时最大。
如果所有数的长度都相等,那只用排序就是对的了,这个就可以拿 80 分了。
两个 string 类型的变量相加是将两个变量直接拼接的,这正好符合我们的需求。
那我就举个例子吧:
例子:
可以去试一试这个代码:
#include<bits/stdc++.h>
using namespace std;
string ans;
int n;
string a[25];
bool cmp(string x,string y)
{
return x+y>y+x;
}
int main()
{
cin>>n;
for(int i=1;i<=n;i++)
cin>>a[i];
sort(a+1,a+n+1,cmp);
for(int i=1;i<=n;i++)
ans+=a[i];
cout<<ans;
return 0;
}