题意简述
给定 个正整数 ,将它们首尾相接,求能组成的最大整数。
解题思路
定义字符串集合 上的二元关系 :
其中 表示字符串 和 的拼接。
设 为字符串 对应的数值, 为 的长度。构造映射 :
由实数域上 的传递性和非对称性,可知 在 上满足 严格弱序。
假设最优排列 存在相邻逆序 ,交换两者得到 。
由于 ,且交换不影响前后缀的数值贡献。故 总数值严格增大,与 为最优解矛盾。
因此,最优解为按 降序的排列。
时间复杂度为 。
参考代码
#include <bits/stdc++.h>
using namespace std;
int main()
{
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n;
cin>>n;
vector<string> a(n);
for(auto &s:a)cin>>s;
sort(a.begin(),a.end(),[](auto x,auto y){return x+y>y+x;});
for(auto s:a)cout<<s;
return 0;
}