加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

大数阶乘

发布时间:2020-12-14 04:14:05 所属栏目:大数据 来源:网络整理
导读:// 阶乘.cpp : 定义控制台应用程序的入口点。 // #include "stdafx.h" #include stdio.h #include math.h #include stdlib.h /* 求N!的位数公式 log10(1)+log10(2)+···+log10(n) 取整加1 */ int wei(int n) { ?int i; ?double sum=0; ?for(i=1;i=n;i++) ?

// 阶乘.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h" #include <stdio.h> #include <math.h> #include <stdlib.h> /* 求N!的位数公式 log10(1)+log10(2)+···+log10(n) 取整加1 */ int wei(int n) { ?int i; ?double sum=0; ?for(i=1;i<=n;i++) ??sum+=log10((double)i); /* 以万为进制,一位可以表示4个数,减少存储空间 */ ?return (int)((sum+1)/4+1); } /* 高精度阶乘核心 */ int _tmain(int argc,_TCHAR* argv[]) { ?int i,j,n,k,m=0,jinwei,weishu=1,temp; ?unsigned int *x; ?scanf("%d",&n); /* 依据阶乘位数申请动态数组 */ ?x=(unsigned int*) malloc(wei(n)*sizeof(int)); ?x[0]=1; ?for(i=2;i<=n;i++) ?{ ??jinwei=0; ???? for(j=1;j<=weishu;j++) ??{ ??? ???temp=x[j-1]*i+jinwei; ??? ???if (temp>=1) ???{ /* 以万为进制,提高运算速度 */ ????x[j-1]=temp%10000; ????jinwei=temp/10000; ???} ??} ? ??while(jinwei) ??{ ???weishu++; ???x[weishu-1]=jinwei%10000; ???jinwei/=10000; ???? ??} ?} /* 先输出第一个数,防止首位出现0 */ ?printf("%d",x[weishu-1]); ??? for(j=weishu-2;j>=0;j--) printf("%04d",x[j]); /* 输出其余的数,因为万进制,需要补0 */ ?system("pause"); ?return 0; ? }

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读