NYOJ 1233 差值

差值

时间限制:3000 ms  |  内存限制:65535 KB


描述

     输入一个整数数组,将它们连接起来排成一个数,找出能排出的所有数字中最大,最小的两个,输出两个数的差值。例如输入数组{1,  2},则输出9


输入
第一行输入一个整数T,表示有T组测试数据。每组测试数据的第一行输入一个整数n(0<n<=1000),第二行输入n个整数ai(0<=ai<2^32)。
输出
输出最大数最小数的差值,输出占一行。
样例输入
     
     
1
3
1 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;
}
        



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值