差值
时间限制:3000 ms | 内存限制:65535 KB
描述
这道题不能简单地用sort对输入的n个数进行排序,例如 2,9,11,排序后变成了1192,不是我们要的最大数,最大数应该是9211,所以我想到了用字符串进行排序,代码如下
输入一个整数数组,将它们连接起来排成一个数,找出能排出的所有数字中最大,最小的两个,输出两个数的差值。例如输入数组{1, 2},则输出9。
-
输入
- 第一行输入一个整数T,表示有T组测试数据。每组测试数据的第一行输入一个整数n(0<n<=1000),第二行输入n个整数ai(0<=ai<2^32)。 输出
- 输出最大数最小数的差值,输出占一行。 样例输入
-
131 2 3
样例输出
-
198
这道题不能简单地用sort对输入的n个数进行排序,例如 2,9,11,排序后变成了1192,不是我们要的最大数,最大数应该是9211,所以我想到了用字符串进行排序,代码如下
bool Cmp(const string &s, const string &t)
{
string st = s + t;
string ts = t + s;
return st > ts;
}
int main()
{
......
vector<string> integers;
string str;
char s[20];
int i,j;
for (i = 0; i < n; ++i)
{
scanf("%s",s);
str = s;
integers.push_back(str);
}
sort(integers.begin(), integers.end(), Cmp);
......
return 0;
}
但不管怎么改,依旧超时,然后我搜了别人的代码来看,用的结构体储存每位数,然后进行结构体排序
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
struct str
{
char s[20];
} sub[1005];
bool cmp(str a,str b)
{
int i;
int len1=strlen(a.s);
int len2=strlen(b.s);
int x=max(len1,len2);
for(i=0; i<x; i++) //对每位数进行比较
{
if(a.s[i%len1]<b.s[i%len2])
return 1;
else if(a.s[i%len1]>b.s[i%len2])
return 0;
}
return 1;
}
int main()
{
int t,len,i,j,n;
char s[20050];
int a1[20050],a2[20050];
scanf("%d",&t);
while(t--)
{
scanf("%d",&n);
for(i=0; i<n; i++)
scanf("%s",sub[i].s);
sort(sub,sub+n,cmp);//从小到大的排序
memset(s,0,sizeof(s));
for(i=0; i<n; i++)
strcat(s,sub[i].s);
len=strlen(s);
for(j=0,i=0; i<len; i++)//a1储存最小值
a1[j++]=s[i]-'0';
memset(s,0,sizeof(s));
for(i=n-1; i>=0; i--)
strcat(s,sub[i].s);
for(j=0,i=0; i<len; i++)//a2储存最大值
a2[j++]=s[i]-'0';
for(i=len-1; i>=0; i--)
{
a2[i]=a2[i]-a1[i];
if(a2[i]<0)
{
a2[i]+=10;
a2[i-1]-=1;
}
}
for(i=0; i<len; i++)
if(a2[i])break;
if(i==len)
printf("0");
for(; i<len; i++)
printf("%d",a2[i]);
printf("\n");
}
return 0;
}