大数乘法问题(C++版)

近日参加一个笔试,遇到大数乘法问题,这是一个经典的算法题。所谓大数乘法问题其实就是这样的:输入两个整数,要求输出这两个数的乘积。输入的数字可能超过计算机内任何数据的存储范围。这里主要需要注意的点就是需要使用字符串或者字符数组来存储这两个大数以及他们的结果,还有乘法计算过程中存在乘法进位和加法进位。

我先自己尝试写了一个答案,思路就是模拟手写竖式乘法。

    static string MYMULTIPLY(const string &number1, const string &number2)
    {
        int length1 = number1.size();
        int length2 = number2.size();
        string result = "";

        if (length1 == 0 || length2 == 0)
        {
            result = "error";
            return result;
        }

        int *iresult;
        iresult = (int*)malloc(sizeof(int) * (length1 + length2 + 1));
        memset(iresult, 0, sizeof(int) * (length1 + length2 + 1));

        for(int i = length1 - 1, x = 0; i >= 0; i--, x++)
        {
            int numA = number1[i] - 48;
            int value1 = 0;
            int value2 = 0;
            int multiFlag = 0;//乘法进位数
            int addFlag = 0;//加法进位数

            for(int j = length2 - 1, y = 0; j >= 0; j--, y++)
            {
                int numB = number2[j] - 48;
                value1 = numA * numB + multiFlag;
                multiFlag = value1 / 10;
                value1 = value1 % 10;
                value2 = (iresult[x+y]) + value1 + addFlag;
                addFlag = value2 / 10;
                iresult[x+y] = (value2 % 10); 
            }
            iresult[x + length2] += (multiFlag + addFlag);
        }

        //逆序
        int i = 0;
        for(i = length1 + length2 - 1; i >= 0; i--)
        {
            if(iresult[i] != 0)
                break;
        }

        for(; i >= 0; i--)
        {
            result = result + (char)(iresult[i]+48);
        }

        free(iresult);

        return result;
    }

这个方法虽然能得出结果,但是太难看了,特别是计算每一位相乘的结果和进位的那一段代码。之后,我就把这段代码改进了一下,将每一位之间的乘法和进位计算分开来。

    static string MULTIPLY(string number1, string number2)
    {
        int i, j;
        int *iresult;
        int length1 = number1.size();
        int length2 = number2.size();
        string result = "";

        reverse(number1.begin(), number1.end());
        reverse(number2.begin(), number2.end());

        if (length1 == 0 || length2 == 0)
        {
            result = "error";
            return result;
        }

        iresult = (int*)malloc(sizeof(int) * (length1 + length2 + 1));
        memset(iresult, 0, sizeof(int) * (length1 + length2 + 1));

        //每一位相乘
        for(i = 0; i < length1; i++)
        {
            for(j = 0; j < length2; j++)
            {
                iresult[i+j] += ((number1[i] - 48) * (number2[j] - 48));
            }
        }

        //进位运算
        int carry = 0;
        for(i = 0; i < length1 + length2; i++)
        {
            int value = iresult[i] + carry;
            iresult[i] = value % 10;
            carry = value / 10;
        }

        for(i = length1 + length2 - 1; i >= 0; i--)
        {
            if(iresult[i] != 0)
            break;
        }

        for(; i >= 0; i--)
        {
            result = result + (char)(iresult[i]+48);
        }

        free(iresult);

        if(result == "") result = "0";
        return result;
    }

当然这个问题还有分治乘法,快速傅里叶等算法,这个就不是在笔试或者面试的时候能快速写出来的了。有兴趣大家可以继续深入了解下。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,378评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,356评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,702评论 0 342
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,259评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,263评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,036评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,349评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,979评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,469评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,938评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,059评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,703评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,257评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,262评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,485评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,501评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,792评论 2 345

推荐阅读更多精彩内容

  • 一、计算机的发展史 01改变世界:没有计算器的日子怎么过——手动时期的计算工具 所谓计算机,顾名思义,就是用于计...
    文思汇集阅读 2,678评论 1 8
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,581评论 18 399
  • 贪心算法 贪心算法总是作出在当前看来最好的选择。也就是说贪心算法并不从整体最优考虑,它所作出的选择只是在某种意义上...
    fredal阅读 9,206评论 3 52
  • 2017年4月26日 天气雨 星期三 经典有好几本,有易经、有唐诗三百首、有老子、还有幼雪琼林,我们还...
    琦琦花仙子小月阅读 150评论 1 3
  • 如果时钟的存在是为了提醒萎靡不振的人们不断赛跑。那过往是否可以容纳未来的光。 如果生活的瞬息万变是在告知我们需要勇...
    蚕食阅读 363评论 3 1