Cod sursa(job #1484412)

Utilizator BlaugranasEnal Gemaledin Blaugranas Data 11 septembrie 2015 09:51:16
Problema Next Scor 10
Compilator c Status done
Runda Arhiva de probleme Marime 0.7 kb
#include<stdio.h>
#include<string.h>
char s[1000005];
int x[20],y[20],n,i,k,j,t,l,r,f[1000005];
long long d,m;
int main() {
    freopen("next.in","r",stdin),freopen("next.out","w",stdout),fgets(s,1000005,stdin),scanf("%lld",&d),n=strlen(s)-1;
    for(f[0]=0,i=n-1;i>=0;i--)
        f[++f[0]]=s[i]-'0';
    for(m=0,i=f[0];i;i--)
        m=(m*10+f[i])%d;
    for(y[0]=0;d;y[++y[0]]=d%10,d/=10);
    for(x[0]=0;m;x[++x[0]]=m%10,m/=10);
    for(t=0,i=1;i<=f[0]||i<=y[0]||t;i++,t/=10)
        f[i]=(t+=f[i]+y[i])%10;
    for(f[0]=i-1,t=0,i=1;i<=f[0];i++)
        f[i]-=((i<=x[0])?x[i]:0)+t,f[i]+=(t=f[i]<0)*10;
    for(;f[0]>1&&!f[f[0]];f[0]--);
    for(i=f[0];i;i--)
        printf("%d",f[i]);
}