有以下程序
void f(int a[], int i, int j)
{ int t;
if(i<j)
{ t=a[i]; a[i]=a[j]; a[j]=t;
f(a,i+1,j-1);
}
}
main()
{ int i, aa[5]={1,2,3,4,5};
f(aa,0,4);
for(i=0; i<5; i++) printf("%d,",aa[i]);printf("\n");
}
执行后输出结果是
A)5,4,3,2,1, B)5,2,3,4,1, C)1,2,3,4,5, D)1,5,4,3,2,
答案:A
解析:f(aa,0,4)调用是地址双向传递.i=0,j=4,交换aa=[0]、aa[4]的值使aa[5]={5,4,3,2,1};接着递归调用f(a,i+1,j-1)即f(a,1,3),交换aa[1]、aa=[3]的值使aa[5]={5,4,3,2,1};接着递归调用f(a,i+1,j-1)即f(a,2,2),由于i=j=2,退出函数调用,依次输出aa[5]的数组元素为"5,4,3,2,1,"
(47)有以下程序
struct STU
{ char name[10];
&nb此文共有4页 上一页 1 2 3 4 下一页 |