| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1835 人关注过本帖
标题:求n的阶乘各位数之和,
只看楼主 加入收藏
a1004573547
Rank: 2
等 级:论坛游民
帖 子:78
专家分:25
注 册:2013-3-11
结帖率:40%
收藏
已结贴  问题点数:20 回复次数:7 
求n的阶乘各位数之和,
1<n<=50
求各个位的数字的和
2013-04-06 10:39
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
50太大了

DO IT YOURSELF !
2013-04-06 10:39
a1004573547
Rank: 2
等 级:论坛游民
帖 子:78
专家分:25
注 册:2013-3-11
收藏
得分:0 
回复 2楼 wp231957
题目给的就是50 的
2013-04-06 10:41
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:1 
50!=3.0414093201713378043612608166065e+64

这是用windows的计算器算的结果  实在是太大了

DO IT YOURSELF !
2013-04-06 10:43
Susake
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:女儿国的隔壁
等 级:贵宾
威 望:23
帖 子:2288
专家分:6481
注 册:2012-12-14
收藏
得分:19 
程序代码:
#include <stdio.h>
#include <string.h>
#define max 3000
int f[max];

int main() {
    int i, j, n, c, s, sum;
    scanf("%d", &n);
    f[0] = 1;
    for(i = 2; i <= n; i++) {
        c = 0;
        for(j = 0; j < max; j++) {
            s = f[j] * i + c;
            f[j] = s % 10;
            c = s / 10;
        }
    }
    for(j = max - 1; j >= 0; j--)
        if(f[j]) break;
    for(i = j; i >= 0; i--) printf("%d", f[i]);
    printf("\n");
    sum = 0;
    for(i = j; i >= 0; i--) sum += f[i];
    printf("%d\n", sum);
    return 0;
}
给出我代码,有兴趣的可以想想...

仰望星空...........不忘初心!
2013-04-06 10:47
a1004573547
Rank: 2
等 级:论坛游民
帖 子:78
专家分:25
注 册:2013-3-11
收藏
得分:0 
c是进位s是第某个数的乘积f[i]为n!的倒置位,倒数第i+1位
2013-04-06 11:45
a1004573547
Rank: 2
等 级:论坛游民
帖 子:78
专家分:25
注 册:2013-3-11
收藏
得分:0 
回复 5楼 Susake
谢了
2013-04-06 11:46
梅可伟梅可伟
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:69
专家分:180
注 册:2013-3-11
收藏
得分:0 
#include <stdio.h>//用数组来处理(因为数太大,无论长长整型,还是double型都不能达到目的)
#define M 1000
int a[M]={0};
void main()
{
    int n=50,i,j;
    a[M-1]=1;
    for(j=1;j<=n;j++)
    {
        for(i=M-1;i>=0;i--)
            a[i]=a[i]*j;
        for(i=M-1;i>0;i--)
        {
            a[i-1]+=a[i]/10;
            a[i]=a[i]%10;
        }
    }
    for(i=0;i<M;i++)
    {
        if(a[i]!=0) break;
    }
    j=i;
    for(i=j;i<M-1;i++)
        printf("%d",a[i]);
    printf("\n");
}
2013-04-06 12:13
快速回复:求n的阶乘各位数之和,
数据加载中...
 
   



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

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