首页 > 代码库 > 高精度运算-阶乘累积求和
高精度运算-阶乘累积求和
# include <stdio.h># include <math.h># define N 66int main(){ int s[N] = {0}, a[N] = {0};// s累加和,a累积求阶乘 int i,j,k,n,digit=1; //digit代表的是数字的位数 scanf("%d",&n); a[0]=1; s[0]=1; if(n==1)// 如果是1,阶乘和就是1,直接输出 printf("%d",s[0]); for(k=2;k<=n;k++){//如果n>1,从2的阶乘开始累加。 for(j=0;j<digit;j++) a[j] *= k; for(j=0;j<digit;j++){ if(a[j]>=10){ a[j+1] += a[j]/10; a[j] = a[j]%10; if(j == digit-1) digit++; } } for(i=0;i<digit;i++) s[i] += a[i]; for(i=0;i<digit;i++){ if(s[i]>=10){ s[i+1] += s[i]/10; s[i]=s[i]%10; if(i == digit-1) digit++; } } } for(i=digit-1;i>=0;i--){ printf("%d",s[i]); } return 0;}
高精度运算-阶乘累积求和
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。