栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > C++面试题库

大整数数相乘的问题。(这是2002年在一考研班上遇到的算法题)

大整数数相乘的问题。(这是2002年在一考研班上遇到的算法题)

void Multiple(char A[], char B[], char C[]) {

    int TMP, In=0, LenA=-1, LenB=-1;

    while(A[++LenA] != ‘’);

    while(B[++LenB] != ‘’);

    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<sizeof(C); k++)

        C[k] = ‘0’;

    C[sizeof(C)-1] = ‘’;

 

    Multiple(A, B, C);

    for(int i=0; C[i] != ‘’; i++)

        printf(“%c”, C[i]);

}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/265480.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号