zoukankan      html  css  js  c++  java
  • 大数乘法

    大数乘法的步骤(先戳我看看大数加法的思想):

    1. 首先我们输入要相乘的2个数字,然后逆序。
    2. 用2层循环来相乘,把下标[i]*[j]计算的结果放在下标[i*j-1]中(下标从1開始),建议及时处理进位问题(char字符范围比較小)。

    3. 最后从高位開始输出。

    #include <iostream>
    #include <cstring>
    #define MAX 1000
    using namespace std;
    void InputNumber(char *num_1,char *num_2)
    {
        char *temp = new char [MAX];//用于存放输入的数据
    
        memset(temp,0,sizeof(temp));cin>>temp;//清空容器并输入第一个数据
        for(int i = num_1[0] = strlen(temp); i>0; i--)
           num_1[i] = temp[ num_1[0] - i ] - '0';//逆序并转换成对应的数字
        memset(temp,0,sizeof(temp));cin>>temp;//清空容器并输入第二个数据
        for(int i = num_2[0] = strlen(temp); i>0; i--)
           num_2[i] = temp[ num_2[0] - i ] - '0';//逆序并转换成对应的数字
    
        delete [] temp;//释放暂时容器
    }
    void ChenNumber(char *num_1,char *num_2,char *sum)
    {
        sum[0] = num_1[0] + num_2[0];
        for(int i=1; i <= num_1[0]; i++)
           for(int j=1; j <= num_2[0]; j++)
           {
               sum[ i + j - 1 ] += num_1[i] * num_2[j];
               sum[ i + j ] += sum[ i + j - 1 ] / 10;
               sum[ i + j - 1 ] %= 10;
           }
    }
    void OutputNumber(char *sum)
    {
        for(int i = sum[0]; !sum[i] && 1 < i; sum[0]--,i--)
           ;//过滤前导0;避免结果所有是0,所以仅仅留下一位只是滤
        for(int i = sum[0]; i > 0; i--)
           cout<<(int)sum[i];//输出结果
        cout<<endl<<endl;
    }
    int main(void)
    {
        while(true)
        {
            char *num_1 = new char [MAX];memset(num_1,0,sizeof(num_1));//存放乘数,并清空
            char *num_2 = new char [MAX];memset(num_2,0,sizeof(num_2));//存放乘数,并清空
            char *num_3 = new char [MAX];memset(num_3,0,sizeof(num_3));//存放结果,并清空
            InputNumber(num_1,num_2);//输入2个乘数
            ChenNumber(num_1,num_2,num_3);//计算相乘
            OutputNumber(num_3);//输出结果
    
            delete [] num_1;delete [] num_2;delete [] num_3;
        }
        return 0;
    }

  • 相关阅读:
    逗号操作符使用小技巧
    字符解码?
    画图 wx.Window pen
    进程和线程
    内存管理
    简单的文本编辑器
    迭代器 Iterator
    文件操作
    ebay api学习
    一,wxpython入门
  • 原文地址:https://www.cnblogs.com/zfyouxi/p/4075930.html
Copyright © 2011-2022 走看看