递推求阶乘大数

本文介绍了一个使用C语言编写的程序,该程序能够计算任意正整数的阶乘,并展示了如何通过逐步增加来更新一个大整数数组表示的大数。程序首先定义了一个大数数组并初始化为1,然后通过自定义的pnext函数逐步累加,最终输出从1到给定数值的阶乘结果。
#include<stdio.h>
#include<malloc.h>
#define MAXN 1000

void pnext(int a[], int k)
{
    // 这里的m代表有几位
    int *b, m = a[0];
    int i, j, r, carry;
    b = (int *)malloc(sizeof(int) * (m + 1));
    // b 相当于把前面的值保存下来
    for (i = 1; i <= m; i++)
    {
        b[i] = a[i];
    }

    // 多加k次
    for (j = 1; j < k; j++)
    {
        // carry 进位值
        for (carry = 0, i = 1; i <= m; i++)
        {
            r = (i <= a[0] ? (a[i] + b[i]) : a[i]) + carry;
            a[i] = r % 10;   // 个位数
            carry = r / 10;  // 求其是否还有高位
        }
        if (carry != 0)
        {
            a[++m] = carry;
        }
    }
    free(b);

    // 更新 m
    a[0] = m;
}

// 计算k!
void write(int *a, int k)
{
    printf("%4d! =", k);
    for (int i = a[0]; i > 0; i--)
    {
        printf("%d", a[i]);
    }
    printf("\n");
}
void main()
{
    int Num[MAXN], n;
    printf("Enter the number n:");
    scanf("%d", &n);
    Num[0] = 1;
    Num[1] = 1;
    write(Num, 1);

    for (int i = 2; i <= n; i++)
    {
        pnext(Num, i);
        write(Num, i);
    }
}
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值