地方生联盟

 找回密码
 注册

QQ登录

只需一步,快速开始

ZT   二级C语言典型题解析

[复制链接]
发表于 2005-6-3 16:47:24 | 显示全部楼层 |阅读模式
1 有以下程序

void f(int a[], int i, int j)

{ int t;

if(i<j)

{ t=a; a=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);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,"



2 有以下程序

struct STU

{ char name[10];

&nb

sp; 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=&s;

for(i=0; i<4; i++)

for(j=i+1; j<5; j++)

if(p->Score > p[j]->Score)

{ t=p; p=p[j]; p[j]=t;}

printf("%d %d\n", s[1].Score, p[1]->Score);

}&

nbsp;

执行后输出结果是

A)550 550 B)680 680 C)580 550 D)580 680

答案:C
解析:本题算法类似于"冒泡排序",它是依次将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.

3 有以下程序(提示:程序中fseek(fp, -2L*sizeof(int), SEEK_END);语句的作用是使位置指针从文件末尾向前移2*sizeof(int)字节)

#include <stdio.h>

main()

{ FILE *fp; int i, a[4]={1,2,3,4},b;

fp=fopen("data.dat", "wb");

for(i=0;i<4;i++) fwrite(&a,sizeof(int),1, fp);

fclose(fp);

fp=fopen("data.dat", "rb");

fseek(fp, -2L*sizeof(int), SEEK_END);

fread(&b, sizeof(int), 1, fp); /* 从文件中读取sizeof(int)字节的数据到变量b中*/

fclose(fp);

printf("%d\n", b);

}

执行后输出结果是 A)2 B)1 C)4 D)3

答案:D
解析:本程序先是建立一个二进制文件data.dat,并从数组a[4]中取出四个整型变量数据块写入该文件,从该文件中位置指针处开始取一个整型变量数据块给变量b即b=3.





发表于 2005-6-7 15:05:34 | 显示全部楼层

re:解析都是对的,但是程序写的有问题,如果第...

解析都是对的,但是程序写的有问题,如果第一个运行的话会core掉的,一个是数组,一个是固定值不可以赋值的。类型不匹配。要做修改的!
估计是从树上或者其他文章上复制过来的吧。你可以在机器上执行一下试试看!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|Archiver|手机版|小黑屋|地方生联盟 ( 沪ICP备10219162号-68 )

GMT+8, 2025-8-31 11:58 , Processed in 0.039304 second(s), 15 queries .

Powered by Discuz! X3.4 Licensed

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表