| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 345 人关注过本帖
标题:C语言中如果处理大数的问题?
只看楼主 加入收藏
长歌、
Rank: 2
来 自:河南省济源市
等 级:论坛游民
帖 子:10
专家分:16
注 册:2013-7-1
结帖率:0
收藏
已结贴  问题点数:20 回复次数:3 
C语言中如果处理大数的问题?
例如 对N!的运算 0<=N<=10000
搜索更多相关主题的帖子: C语言 
2014-04-18 20:08
ying8501
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:6
帖 子:1092
专家分:1446
注 册:2008-11-24
收藏
得分:7 
#include<stdio.h>
#define MAX 1000

int main(void)
{
    int n;
    while(scanf("%d",&n)==1&&n>=0)
    {
        int i,j;
        int a[MAX];      //存数运算结果
        int p,h;           //p存储当前结果的位数,h为进位
        a[1]=1;
        p=1;  
        for(i=2;i<=n;i++)   //循环与2,3,4.....n相乘
        {
            for(j=1,h=0;j<=p;j++)    //让a[]的每位与i相乘
            {
                a[j]=a[j]*i+h;
                h=a[j]/10;
                a[j]=a[j]%10;
            }
            while(h>0)         //如果h不为0
            {
                a[j]=h%10;
                h=h/10;
                j++;
            }
            p=j-1;            //将当前的位数赋给p
        }
        for(i=p;i>=2;i--)
        {
            printf("%d",a[i]);
        }
        printf("%d\n",a[i]);
    }
    return 0;
}
作者:海子
    
出处:http://
    
2014-04-18 20:22
dongshimou
Rank: 3Rank: 3
等 级:论坛游侠
威 望:2
帖 子:44
专家分:152
注 册:2014-1-8
收藏
得分:7 
数组。
→ → 我比较挫,自己写的计算10000!需要 0.48秒。
2014-04-18 21:01
a1092909114
Rank: 2
等 级:论坛游民
帖 子:27
专家分:39
注 册:2014-4-18
收藏
得分:7 
我是新手没有看懂 怎么实现的 弄的进位什么意思?
2014-04-18 22:05
快速回复:C语言中如果处理大数的问题?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.037009 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved