码迷,mamicode.com
首页 > 其他好文 > 详细

大数阶乘

时间:2019-01-20 12:08:57      阅读:200      评论:0      收藏:0      [点我收藏+]

标签:size   for   str   乘法   数组   pre   max   计算   src   

当求阶乘的数太大的时候,结果用int甚至long无法保存,可以用一个大数组来保存结果,运算的方法和笔算乘法类似。比如456 * 6的运算步骤如下:

  1. 数组num[0], num[1], num[2]分别存储456的个位、十位、百位
  2. 每一位与6相乘,相乘的结果+上一位的进位carry 的个位存储在该数组单元
  3. 计算要向上一位进位的carry
    技术分享图片
#include <iostream>
using namespace std;

#define maxsize 4000

int main(){
    int num[maxsize] = {0};
    int carry, t, n;// t用于记录当前结果的位数,carry为进位
    num[0] = 1;
    int ca;
    while(cin >> n){
        t = 0;
        num[0] = 1;
        for(int i = 1; i <= n; i++){// 计算阶乘,从1开始乘到n
            carry = 0;// 
            for(int j = 0; j <= t; j++){// 对于每个结果的每一位
                ca = (num[j] * i + carry) / 10;// 计算出这一位乘以i的进位
                num[j] = (num[j] * i + carry) % 10;要保存在这一位的结果
                carry = ca;
            }
            while(carry != 0){// 每一个数如果carry!=0就说明要向上一位进位
                num[++t] = carry % 10;
                carry = carry / 10;
            }
        }
        for(int i = t; i >= 0; i--)// 输出结果
            cout << num[i];
        cout << endl;
    }
    return 0;
}

大数阶乘

标签:size   for   str   乘法   数组   pre   max   计算   src   

原文地址:https://www.cnblogs.com/zhuobo/p/10293665.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!