大整数数相乘的问题。

admin2019-03-29  48

问题 大整数数相乘的问题。

选项

答案void Multiple(char A[], char B[], char C[]) { int TMP, In=0, LenA=-1, LenB=-1; while(A[++LenA] != ’\0’); while(B[++LenB] != ’\0’); int Index, Start = LenA + LenB - 1; for(int i=LenB-1; i>=0; i--) { Index = Start--; if(B[i] != ’0’){ for(int In=0, j=LenA-1; j>=0; j--) { TMP = (C[Index]-’0’) + (A[j]-’0’) * (B[i] - ’0’) + In; C[Index--] = TMP % 10 + ’0’; In = TMP / 10; } C[Index] = In + ’0’; } } } int main(int argc, char* argv[]) { char A[] = "21839244444444448880088888889"; char B[] = "38888888888899999999999999988"; char C[sizeof(A) + sizeof(B) - 1]; for(int k=0; k
解析
转载请注明原文地址:https://kaotiyun.com/show/YxmZ777K
0

最新回复(0)