当前位置: 代码迷 >> C语言 >> 我的递归程序错那里了,郁闷
  详细解决方案

我的递归程序错那里了,郁闷

热度:109   发布时间:2004-12-26 17:00:00.0
我的递归程序错那里了,郁闷

#include'stdio.h' void jiecheng(int n,int a[],int b[]) {int s,f; if(n>2) jiecheng(n-1,a,b); else {

for(s=0;s<64;++s) b[s]=a[s]; for(s=1;s<n;s++) { for(f=0;f<64;f++) { a[f]=a[f]+b[f]; if(a[f]>9) {a[f+1]=a[f+1]+1; a[f]=a[f]%10; } } } }

} main(){ int a[64]; int b[64]; int i; for(i=0;i<64;++i) a[i]=0; a[0]=1; jiecheng(1,a,b); for(i=63;i>=0;i--) printf("%d",a[i]); printf(" \n"); jiecheng(2,a,b); for(i=63;i>=0;i--) printf("%d",a[i]); printf(" \n"); jiecheng(3,a,b); for(i=63;i>=0;i--) printf("%d",a[i]); printf(" \n"); jiecheng(4,a,b); for(i=63;i>=0;i--) printf("%d",a[i]); printf(" \n"); jiecheng(5,a,b); for(i=63;i>=0;i--) printf("%d",a[i]); printf(" \n"); jiecheng(6,a,b); for(i=63;i>=0;i--) printf("%d",a[i]); printf(" \n"); printf("1 2 6 24 120 720"); }

搜索更多相关的解决方案: int  递归  jiecheng  void  

----------------解决方案--------------------------------------------------------

#include "stdio.h" void jiecheng(int n,int a[]) { int s,sign,sum; sign=0; for(s=0;s<64;s++) { sum=n*a[s]+sign; a[s]=sum%10; sign=sum/10; } }

void main(){ int a[64]; int i; for(i=0;i<64;++i) a[i]=0; a[0]=1; for(int j=1;j<7;j++) { jiecheng(j,a); for(i=63;i>=0;i--) printf("%d",a[i]); printf("\n"); } } 我改了一下,没有用递归,可以运行,结果正确。你要做的主要是利用数组来存储数字,可以计算较大数据的阶乘,是吗?


----------------解决方案--------------------------------------------------------
是呀,可是老师要求用递归,并且要用数组加法算
----------------解决方案--------------------------------------------------------
你的程序乱了一点,我这里运行是没错的,不太明白你的意思
----------------解决方案--------------------------------------------------------
  相关解决方案