加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

2013 Multi-University Training Contest 1 I-number 大数

发布时间:2020-12-14 04:04:48 所属栏目:大数据 来源:网络整理
导读:这次比赛嘛 ? 由于个人水平比较水没做出其他题就做了这一道 还做第3题 ? ?考的是数论 ? 我认为是这样的 ? ? ?写了 是超时的 悲剧 ? ?? ? ? 继续学 ?以后做出更多 这道题就是纯大数的问题 ? ? ?很多人WA就是去掉了前导零 ? ?例如 ? 输入 001 ?输出是 ?019 ?

这次比赛嘛 ? 由于个人水平比较水没做出其他题就做了这一道

还做第3题 ? ?考的是数论 ? 我认为是这样的 ? ? ?写了 是超时的 悲剧 ? ??

? ? 继续学 ?以后做出更多

这道题就是纯大数的问题 ? ? ?很多人WA就是去掉了前导零 ? ?例如 ? 输入 001 ?输出是 ?019 ?

下面看代码 ?没什么难度 ?写得有点搓

#include<cstdio>
#include<cstring>

const int maxn = 100005;
char  str[maxn],s[maxn],t[maxn];

void Calculate(int& len_str)
{
    int i,j,k;
    for(i = 1; ;i++)
    {
        strcpy(t,str);
        int sum = 0,c = 0;
        for(j = 0; j < len_str; j++)
        {
            int ans = t[j] - '0';
            if(j == 0)
                {c =(ans+i)/10;t[j]=(ans+i)%10+'0'; sum += (ans+i)%10;}
            else
            {
                t[j] = (c+ans)%10+'0';
                sum +=(c+ans)%10;
                c = (c+ans)/10;
            }
        }
        if(c > 0){t[j++] = c +'0';sum += c;}
        if(sum%10==0)
        {
            for(k = j-1;k >= 0; k--)
                printf("%c",t[k]);
            printf("n");
            break;
        }
    }
}

int main()
{
    int T;
    scanf("%d",&T);
    getchar();
    for(int i = 0; i < T; i++)
    {
        gets(s);
        int len_s = strlen(s);
        int len_str = len_s;
        for(int j = 0; j < len_str; j++)
        {
            str[j]=s[--len_s];
        }
        Calculate(len_str);
    }
    return 0;
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读