zoukankan      html  css  js  c++  java
  • 不错的文章

    前面关于思路介绍引用前辈:http://blog.csdn.net/jinyongqing/article/details/13508577的叙述,因为个人思考觉得前辈的概述精简,也特别符合自己所思考,只是自己还未能总结的如此言简意赅。废话少说,内容如下:

    所谓大数相乘,就是指数字比较大,相乘的结果超出了基本类型的表示范围,所以这样的数不能够直接做乘法运算。
    其实乘法运算可以分拆为两步:第一步,是将乘数与被乘数逐位相乘;第二步,将逐位相乘得到的结果,对应相加起来。这有点类似小学数学中,计算乘法时通常采用的“竖式运算”。
    这里唯一要注意的便是进位问题,我们可以先不考虑进位,当所有位对应相加,产生结果之后,再考虑如果该位的数字大于10,那么我们用取余运算,在该位上只保留取余运算的结果,而将进位(通过模运算得到)累加到下一位便可。

    注:大数a和大数b相乘结果位数为aLen+bLen(最高位有进位)或者aLen+bLen-1(最高位无进位),aLen和bLen分别为数a和数b的长度,另外相乘结果result[i + j] = a[i] * b[j];

    自己实现代码如下:

    1. #include <stdio.h> 
    2. #include <string.h> 
    3. #include <stdlib.h> 
    4.  
    5.  
    6. void Multiply(char *a, char *b, char *result) 
    7.     int i, j, aLen, bLen, sLen, *s; 
    8.  
    9.     aLen = strlen(a); 
    10.     bLen = strlen(b); 
    11.  
    12.     sLen = sizeof(int) * (aLen + bLen); 
    13.  
    14.     s = (int *)malloc(sLen); 
    15.  
    16.     memset(s, 0, sLen); 
    17.  
    18.     //a的每一位分别乘以b的每一位,并把最终结果对应位置上的数值累加,可能该位置上的数字大于10 
    19.     for(i = 0; i < aLen; i++) 
    20.     { 
    21.         for(j = 0; j < bLen; j++) 
    22.         { 
    23.             //s数组位i+j+1是为防止结果长度为aLen + bLen -1时(即最高位无进位),最后一位补充0,结果出错 
    24.             s[i + j + 1] += (a[i] - '0') * (b[j] - '0'); 
    25.         } 
    26.     } 
    27.  
    28.     //把最终结果 有一位置上为大于10的数字 向前进位 
    29.     for(i = aLen + bLen; i >= 0; i--) 
    30.     { 
    31.         if(s[i] >= 10) 
    32.         { 
    33.             s[i - 1] += s[i]/10; 
    34.             s[i] = s[i]%10; 
    35.         } 
    36.     } 
    37.  
    38.     i = 0; 
    39.     //如果最高位无进位时则从s[1]开始赋值给result 
    40.     while(s[i] == 0) 
    41.     { 
    42.         i++; 
    43.         //防止乘数或者被乘数有0存在,结果为0这样可以打印出0 
    44.         if(s[i] == 0) 
    45.         { 
    46.             result[0] = '0'; 
    47.             free(s); 
    48.             return; 
    49.         } 
    50.  
    51.     } 
    52.  
    53.     for(j = 0; i < aLen + bLen; i++, j++) 
    54.     { 
    55.         result[j] = s[i] + '0'; 
    56.     } 
    57.     result[j] = ''; 
    58.  
    59.     free(s); 
    60.  
    61. int main(int argc, char* argv[]) 
    62.     int i = 0; 
    63.     char a[] = "123"; 
    64.     char b[] = "456"; 
    65.     char c[100] = {0}; 
    66.  
    67.     Multiply(a, b, c); 
    68.  
    69.     for(int i = 0; i < sizeof(c); i++) 
    70.     { 
    71.         printf("%c ", c[i]); 
    72.     } 
    73.     printf(" "); 
    74.  
    75.     return 0; 
  • 相关阅读:
    在PHP中如何获取来源URL
    函数中的static关键字
    ubuntu server 10.04 上安装oracle 10G 开发版
    ajax同步和异步提交的区别
    jQuery对Select的操作集合[终结篇]
    从IFARME中直接跳转到外层页面
    用mount命令挂载远程文件系统
    js小技巧(输入框提示信息自动消失)
    js 获取事件源
    Oracle PL/SQL中如何使用%TYPE和%ROWTYPE
  • 原文地址:https://www.cnblogs.com/zhangbing12304/p/7965988.html
Copyright © 2011-2022 走看看