为什么不能得满分,代码是哪里出错了?

1022 D进制的A+B (20 分)

输入两个非负 10 进制整数 A 和 B (≤2​30​​−1),输出 A+B 的 D (1<D≤10)进制数。

输入格式:

输入在一行中依次给出 3 个整数 A、B 和 D。

输出格式:

输出 A+B 的 D 进制数。

输入样例:

123 456 8

输出样例:

1103
#include <stdio.h>
int main (){
    long int A,B,amount=0;
    int d,all=0,n=1,tmp;
    scanf("%ld%ld%d",&A,&B,&d);
    all=A+B;
    while(all>0){
        tmp=all%d;
        amount+=tmp*n;
        all/=d;
        n*=10;
    }
    printf("%ld",amount);
    return 0;
}

 抓耳挠腮,苦思冥想都找不出来,求大佬指教。

数字太大,会超限,比如:A=99999999,B=99999999,D=2,那么结果肯定出不来,n和all都太小了,容量不够