大数运算之100的阶乘(c语言实现)

博客聚焦于大数运算中的阶乘问题,如100的阶乘这类大数阶乘的计算。大数阶乘在信息技术领域有重要应用,涉及特定的算法和处理方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/*
*   100以内的阶乘(还可以更大,只需把arr[256]调到更大)
*   @author 李政 <1244109467@qq.com>
*/
#include <stdio.h>

void factorial(int n, char *pout)
{
    if(pout == NULL)
    {
        return;
    }

    int arr[256];
    int idx = 1;
    arr[0] = 1;
    //此处要注意 i从1开始
    for(int i = 1; i <= n; i++)
    {
        //cry用来记录进位
        int cry = 0;
        // idx记录现在有多少位 挨个相乘
        for(int j = 0; j < idx; j++)
        {
            arr[j] = arr[j] * i + cry;
            //此处用倒序存储
            cry = arr[j] / 10;
            arr[j] %= 10;
        }
        //如果进位大于10 要降级
        while(cry > 10)
        {
            arr[idx++] = cry % 10;
            cry /= 10;
        }
        //进位到这里如果还大于 0 证明位数要加1
        if(cry > 0)
            arr[idx++] = cry;
    }
    //将数组倒序赋值给字符串
    for(int i = idx - 1; i >= 0; i--)
    {
        *pout++ = arr[i] + '0';
    }
    *pout = '\0';
    return;
}

int main()
{
    char buff[255] ={};
    int n = 0;
    printf("input n:");
    scanf("%d",&n);
    factorial(n,buff);
    puts(buff);
    return 0;
}
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值