| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 853 人关注过本帖
标题:请求一个巨阶算法(1000000!)
只看楼主 加入收藏
梦凡
Rank: 1
等 级:新手上路
帖 子:37
专家分:0
注 册:2004-12-7
收藏
 问题点数:0 回复次数:9 
请求一个巨阶算法(1000000!)

请求一个巨阶算法:1000000!

请说明解答过程及原理!谢谢!

搜索更多相关主题的帖子: 算法 请求 
2004-12-09 11:23
workhard
Rank: 1
等 级:新手上路
帖 子:96
专家分:0
注 册:2004-11-17
收藏
得分:0 

#include <iostream.h> #include <iomanip.h> #include<math.h> #include<stdlib.h>

int get();//输入n int getBitNum(int n);//得到结果有多少位 char* init(int size);//动态分配空间 void calc(char* a,int n);//计算结果 void display(char *a,int size);//显示结果

void main() { int n=get(); int size=getBitNum(n); char *pa=init(size); calc(pa,n); display(pa,size); delete[]pa; }

int get() { int n; cout<<"请输入n:"; cin>>n; while(n<0) { cout<<"请重新输入n:"; cin>>n; } if(n==0) exit(1); return n;

}

int getBitNum(int n) { double m=1.0; for (int i=1;i<=n;i++) m+=log10(i); return (int)m; }

char* init(int size) { char *pa=new char[size]; if(!pa) { cout<<"分配空间失败"<<endl; exit(1); } pa[0]=1; for(int i=1;i<=size;i++) pa[i]=0; return pa; }

void calc(char* a,int n) { int begin=0; // int sum=0; double bitcount=1; for(int i=2;i<=n;i++) { long jin=0; bitcount+=log10(i); if(a[begin]==0) begin++; for(int l=begin;l<int(bitcount);l++) { jin+=i*a[l]; a[l]=char(jin%10); jin=jin/10; } } }

void display(char *a,int size) { int bit=0; for(int j=size-1;j>=0;j--) {if(bit%50==0) cout<<endl<<"第"<<setw(3)<<(bit/50+1)<<"个50位:"; cout<<(int)a[j]; bit++; } cout<<endl; } 原来写的,自己慢慢看吧,可能还要稍作修改,主要是数据类型。


2004-12-10 10:00
梦凡
Rank: 1
等 级:新手上路
帖 子:37
专家分:0
注 册:2004-12-7
收藏
得分:0 

谢谢啊。老兄!

2004-12-10 10:33
天使预备役
Rank: 2
等 级:论坛游民
威 望:3
帖 子:670
专家分:10
注 册:2004-4-6
收藏
得分:0 
人家用的是女生头像,怎么叫人家“老兄”!!!

差点把你忘了...
2004-12-10 16:52
kaikai
Rank: 1
等 级:新手上路
帖 子:236
专家分:0
注 册:2005-1-7
收藏
得分:0 
1000000!的位数应该有(1+1000000)*1000000/2 &gt; 2^32吧?
465G个数字,大概这个内存是分配不出来的了吧...果然是巨阶-___-|||

Have you visit acm.tongji. lately?
2005-02-24 19:23
kaikai
Rank: 1
等 级:新手上路
帖 子:236
专家分:0
注 册:2005-1-7
收藏
得分:0 
@idealistic33 你遇到的错误我也遇到过,应该是分配的空间在使用过程中有越界。不应该去掉delete,那样更加不对。

Have you visit acm.tongji. lately?
2005-02-24 21:11
Knocker
Rank: 8Rank: 8
等 级:贵宾
威 望:47
帖 子:10454
专家分:603
注 册:2004-6-1
收藏
得分:0 
hehe,楼上的,不要将本人的劣作到处张贴,我要告你侵权的啊

九洲方除百尺冰,映秀又遭蛮牛耕。汽笛嘶鸣国旗半,哀伤尽处是重生。     -老K
治国就是治吏。礼义廉耻,国之四维。四维不张,国之不国。   -毛泽东
2005-02-25 10:35
快速回复:请求一个巨阶算法(1000000!)
数据加载中...
 
   



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

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