-
UID:2
-
- 注册时间2005-10-16
- 最后登录2012-01-01
- 在线时间3141小时
-
- 发帖5692
- 搜Ta的帖子
- 精华
4
- 铜板103378
- 人品值1520
- 贡献值26
- 交易币0
- 好评度5373
- 信誉值0
- 金币0
-
访问TA的空间加好友用道具
- 发帖
- 5692
- 铜板
- 103378
- 人品值
- 1520
- 贡献值
- 26
- 交易币
- 0
- 好评度
- 5373
- 信誉值
- 0
- 金币
- 0
- 所在楼道
|
有以下程序1 /2Q@M> ]"Z*Hq
z +MU|XT_5|6 - 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");
- }
/ZlPEs) 0 UdAF b.V\EOk 1D159 NLB 7) aitDD 执行后输出结果是 AvnK?*5!@ A)5,4,3,2,1, B)5,2,3,4,1, C)1,2,3,4,5, D)1,5,4,3,2, MW*@fl<@?M x@/ N9* h.+{cOA;n 答案:A No#1Ik w %GG:F^X# t '
_Au8 解析:f(aa,0,4)调用是地址双向传递.i=0,j=4,交换aa=[0]、aa[4]的值使 p w(eWP 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," n<\
WVi xLhN3#^m S3EM6 `q' 有以下程序2 4Rj;lAlwB s}yJkQb
KKpO<TO - struct STU
- { char name[10];
- int num;
- int Score;
- };
- main()
- { struct STU s[5]={{"YangSan", 20041, 703},{"LiSiGuo", 20042, 580},
- {"WangYin", 20043, 680},{"SunDan", 20044, 550},
- {"Penghua", 20045, 537}}, *p[5], *t;
- int i,j;
- for(i=0; i<5; i++) p[i]=&s[i];
- for(i=0; i<4; i++)
- for(j=i+1; j<5; j++)
- if(p[i]->Score > p[j]->Score)
- { t=p[i]; p[i]=p[j]; p[j]=t;}
- printf("%d %d\n", s[1].Score, p[1]->Score);
- }
m!{Xu y ,[fn? s r Nb;xJSl ox l,5<g-r
V 执行后输出结果是 ClZ:#uMbN owHV&(Go(B A)550 550 B)680 680 C)580 550 D)580 680 k1Cx~Q)XC 答案:C xdw"JS} k=">2!O/ W3K&C[f 解析:本题算法类似于"冒泡排序",它是依次将p[0]、p[1]、p[2]、p[3]、p[4]分别指向s[5]中成员Score从低到高排列的数组单元,即537、550、580、680、703,而s[5]数组的值不变,因此,s[1].Score=580,p[1]->Score=550. r,F~Vwa} yM}b R(_UR)G0 @ < |