行业资讯 2025年06月7日
0 收藏 0 点赞 566 浏览 852 个字
摘要 :

问题描述   输入一个正整数n,输出n!的值。   其中n!=1*2*3*…*n。 算法描述   n!可能很大,而计算机能表示的整数范围有限,需要使用高精度计算的方法。使用一个数……

问题描述

  输入一个正整数n,输出n!的值。

  其中n!=1*2*3*…*n。

算法描述

  n!可能很大,而计算机能表示的整数范围有限,需要使用高精度计算的方法。使用一个数组A来表示一个大整数a,A[0]表示a的个位,A[1]表示a的十位,依次类推。

  将a乘以一个整数k变为将数组A的每一个元素都乘以k,请注意处理相应的进位。

  首先将a设为1,然后乘2,乘3,当乘到n时,即得到了n!的值。

输入格式

  输入包含一个正整数n,n<=1000。

输出格式

  输出n!的准确值。

样例输入

10

样例输出

3628800

# include <stdio.h>
int main()
{
    int a[10000]={0};
    int i,n,k;
    int weishu=1;
    int carry=0;
    int temp;
    
    a[1]=1;
    scanf("%d", &n);
    
    for (i=1; i<=n; i++)
    {
        for (k=1; k<=weishu; k++)
        {               
            temp = a[k]*i + carry;
            a[k] = temp%10;
            carry = temp/10;
        }
        while (carry)
        {
            a[++weishu] = carry%10;
            carry = carry/10; 
        }
    }   
    
    for (i=weishu; i>=1; i--)
        printf("%d", a[i]);
            
    return 0;
}

原文链接:https://blog.csdn.net/a237653639/java/article/details/21323409

微信扫一扫

支付宝扫一扫

版权: 转载请注明出处:https://www.zuozi.net/4092.html

管理员

相关推荐
2025-08-06

文章目录 一、Reader 接口概述 1.1 什么是 Reader 接口? 1.2 Reader 与 InputStream 的区别 1.3 …

1,048
2025-08-06

文章目录 一、事件溯源 (一)核心概念 (二)Kafka与Golang的优势 (三)完整代码实现 二、命令…

519
2025-08-06

文章目录 一、证明GC期间执行native函数的线程仍在运行 二、native线程操作Java对象的影响及处理方…

380
2025-08-06

文章目录 一、事务基础概念 二、MyBatis事务管理机制 (一)JDBC原生事务管理(JdbcTransaction)…

481
2025-08-06

文章目录 一、SnowFlake算法核心原理 二、SnowFlake算法工作流程详解 三、SnowFlake算法的Java代码…

550
2025-08-06

文章目录 一、本地Jar包的加载操作 二、本地Class的加载方法 三、远程Jar包的加载方式 你知道Groo…

865
发表评论
暂无评论

还没有评论呢,快来抢沙发~

助力内容变现

将您的收入提升到一个新的水平

点击联系客服

在线时间:08:00-23:00

客服QQ

122325244

客服电话

400-888-8888

客服邮箱

122325244@qq.com

扫描二维码

关注微信客服号