计算机二级C语言典型题解析
有以下程序1
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,'
有以下程序2
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);
}
执行后输出结果是
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.
有以下程序(提示:程序中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[i],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.