| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1893 人关注过本帖
标题:[讨论]求N!
只看楼主 加入收藏
mikewolf
Rank: 1
等 级:新手上路
帖 子:175
专家分:0
注 册:2004-7-3
收藏
 问题点数:0 回复次数:10 
[讨论]求N!

问题描述:

比如:

求:1*2*3*4*5*.................*999*1000的结果!

搜索更多相关主题的帖子: 结果 描述 
2004-07-10 14:05
tempnetbar
Rank: 2
等 级:新手上路
威 望:4
帖 子:582
专家分:4
注 册:2004-5-5
收藏
得分:0 

我就写个函数给你看 long step(int n) { int i=1;long j=1; while(i<=n) { j=j*i; i++; } return j; }

[此贴子已经被作者于2004-07-11 07:28:16编辑过]


相信勤能补拙! 喜欢用好用的就永远学不到有用的。
2004-07-10 14:16
mikewolf
Rank: 1
等 级:新手上路
帖 子:175
专家分:0
注 册:2004-7-3
收藏
得分:0 

超过存储范围怎么办!

2004-07-10 18:41
jzh2004
Rank: 1
等 级:新手上路
帖 子:341
专家分:0
注 册:2004-4-30
收藏
得分:0 

用数组存放结果元素


我的主页 http://www.
2004-07-10 21:08
tempnetbar
Rank: 2
等 级:新手上路
威 望:4
帖 子:582
专家分:4
注 册:2004-5-5
收藏
得分:0 

是的,有相关算法,用数组保存结果,一般来说多大都可以,这里只是给出一个思想方法


相信勤能补拙! 喜欢用好用的就永远学不到有用的。
2004-07-11 07:27
mikewolf
Rank: 1
等 级:新手上路
帖 子:175
专家分:0
注 册:2004-7-3
收藏
得分:0 

这个我知道,关键问题在于如何动态确定需要多大空间的数组,一种可能的选择是用链表动态确定,但是这对于实际应用时是不可取的,因为用链表比用数组要慢。所以我个人认为,应当对此问题进行研究,得出一个存储N!所需空间的映射表,在程序执行时直接选择所需要的空间!从执行效率和节省空间考虑!

至于效率可以用如下例程实现:

/*应当注意变量b和m的使用技巧*/

/* 求n! (0<n<10000)*/ #include<stdio.h> #include<conio.h> #include<malloc.h> void cal(unsigned int *s,int n) { unsigned long p,k=0; int i;

/* b用来记录后面的0 ,m用于跟踪应当处理的末尾位置*/ static int m=1,b=0;

for(i=b;i<m;i++) { p=(long)s[i]*(long)n+k; k=p/10000; s[i]=p-k*10000; }

if(!s[b]) { b++; }

if(k){ s[m++]=k; } }

int main(void) { unsigned int *s; int i; int n; scanf("%d",&n); s=(unsigned int *)malloc(n*sizeof(s));

for(i=1;i<n;i++) { s[i]=0; } s[0]=1;

for(i=2;i<=n;i++) { cal(s,i); }

printf("\n%d!=\n",n);

n--; while(!s[n]) { n--; } printf("%d",s[n--]);

for(i=n;i>=0;i--) { printf("%04d",s[i]); } printf("\n"); free(s); getch(); return 0;

}

2004-07-11 21:14
mikewolf
Rank: 1
等 级:新手上路
帖 子:175
专家分:0
注 册:2004-7-3
收藏
得分:0 
oh!   shit!    风格怎么变了呢!
2004-07-11 21:16
mikewolf
Rank: 1
等 级:新手上路
帖 子:175
专家分:0
注 册:2004-7-3
收藏
得分:0 

/*为了便于大家看清楚,重新修改风格*/ /*应当注意变量b和m的使用技巧*/ /* 求n! (0<n<10000)*/ #include<stdio.h> #include<conio.h> #include<malloc.h> void cal(unsigned int *s,int n) { unsigned long p,k=0; int i;

/* b用来记录后面的0 ,m用于跟踪应当处理的末尾位置*/ static int m=1,b=0;

for(i=b;i<m;i++) { p=(long)s[i]*(long)n+k; k=p/10000; s[i]=p-k*10000; }

if(!s[b]) { b++; }

if(k){ s[m++]=k; } }

int main(void) { unsigned int *s; int i; int n; scanf("%d",&n); s=(unsigned int *)malloc(n*sizeof(s));

for(i=1;i<n;i++) { s[i]=0; } s[0]=1;

for(i=2;i<=n;i++) { cal(s,i); }

printf("\n%d!=\n",n);

n--; while(!s[n]) { n--; } printf("%d",s[n--]);

for(i=n;i>=0;i--) { printf("%04d",s[i]); } printf("\n"); free(s); getch(); return 0;

}

2004-07-11 21:19
Knocker
Rank: 8Rank: 8
等 级:贵宾
威 望:47
帖 子:10454
专家分:603
注 册:2004-6-1
收藏
得分:0 

楼上的算法可以说是精品了,若在TC2.0中(即C89标准)可能是最快的算法了。

用long long(C99) 来定义数组不知道会不会更快一点。


九洲方除百尺冰,映秀又遭蛮牛耕。汽笛嘶鸣国旗半,哀伤尽处是重生。     -老K
治国就是治吏。礼义廉耻,国之四维。四维不张,国之不国。   -毛泽东
2004-07-12 00:03
tempnetbar
Rank: 2
等 级:新手上路
威 望:4
帖 子:582
专家分:4
注 册:2004-5-5
收藏
得分:0 
哈哈,mikewolf是想要抛砖引玉啊,我还以为……太好了,我顶!!!

相信勤能补拙! 喜欢用好用的就永远学不到有用的。
2004-07-12 17:28
快速回复:[讨论]求N!
数据加载中...
 
   



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

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