作业帮 > 综合 > 作业

int f(int a[ ],int n){ if(n>1) return a[0]+f(&a[1],n-1);

来源:学生作业帮 编辑:百度作业网作业帮 分类:综合作业 时间:2024/05/05 01:41:54
int f(int a[ ],int n){ if(n>1) return a[0]+f(&a[1],n-1);
int f(int a[ ],int n) { if(n>1) return a[0]+f(&a[1],n-1); else return a[0]; } main() { int aa[3]={1,2,3},s; s=f(&aa[0],3); printf("%d\n",s); } 求详解,没明白f(&a[1],n-1)是怎么回事
int f(int a[ ],int n){ if(n>1) return a[0]+f(&a[1],n-1);
aa:(1,2,3) s=f(&1,3); 在计算时:3>1 返回 1+f(&2,2) f(&2, 2):2还是大于1,就返回2+f(&3,1); f(&3,1):1不大于1了,所以就返回a[0],也就是3. f(&3,1)=3,那么f(&2,2)=2+3=5,f(&1, 3)=1+f(&2,2)=1+5=6 上面我写的&1,&2,&3语法是不对的,只是让你参考用,&1代表指针指向数组aa里的数字1. 看来你还没学过递归吧.