(26)有以下程序:
#include<stdio.h>
main(){
char c[6];
int I=0:
for(;i<6;c[-]=getchar(),i++);
for(I=0;i<6;i++)putchar(c[i]);
primf("\n");
}
如果从键盘上输入:
ab<回车>
c<回车>
def<回车>
则输出结果为_________.
A)a B)a C)ab D)abcdef
b b c
c c d
d d
e
f
答案:C
评析:1.getchar():此函数的作用是从终端(或系统隐含指定的输入设备)输入一个字符。
2.putchar():此函数的作用是向终端输出一个字符,也可以输出控制字符。
本题在输入字符时,ab和c后面的回车符分别赋给了c[2]和e[4],所以,正确答案为c。
(27)在调用函数时,如果实参是简单变量,它与对应形参之间的数据传递方式是_______。
A)地址传递 B)单向值传递
C)由实参传递给形参,再由形参传递给实参
D)传递方式由用户指定
答案:B
评析:c语言规定,实参变量对形参变量的数据传递是"单向值传递",只由实参传给形参。在内存中,实参单元与形参单元是不同的单元。调用结束后,实参单元仍保留并维持原值。
(28)下面程序
#include<stdio.h>
#include<string.h>
main()
{ char*p1="abc",*p2="ABC",str[50]="xyz";
strcpy(str+2,strcat(p1,p2));
printf("%s\n",str);
}
的输出是_________。
A)xyzabcABC B)zabcABC
C)yzabcABC D)xyabcABC
答案:D
评析:strcat(pl,p2)将字符串abcABC放到了*pl所指向的存储单元中;strcpy在本题将abcABC复制到str+2所指向的存储单元中,即覆盖原str数组中的字符z及其后的所有字符,故str的值为"xyabcABC"。
(29)下面程序
int aa[3][3]:{{2},{4},{6}};
main()
{ int i,*p:&aa[0][0];
for(I=0;i<2;i++){
if(i==0)aa[I][i+l]=*p+1;
else++p;
printf("%d'.,。p);
}
}
的输出是__________。
A)23 B)26 C)33 D)36
答案:A
评析:观察题目,可以发现,*p=&aa[01[o]语句实际是将数组aa的首地址赋给了指针变量p,将i的值带入for循环中,i=0时,aa[0][1]=3,+p=2;*p输出的是指针所指向的数组值,此时p所指向的是aa[O][O],输出2,而i=l时执行了++p操作使指针向后移动指向了aa[O儿1],所以在输出*p时应为3。
(30)以下程序的输出结果是_________。
#include<stdio.h>
#include<s~ing.h>
fun(char*w,int n)
{
char t,*s1,*s2;
s1=w;s2=w+n-l:
while(s1<s2)
{
t=*s1++:
*sl=*s2--;
*s2=t;
}
}
main()
{
char*p;
p="1234567";
fun(p,strlen(p));
puts(p);
}
A)1234567 B)7654321 C)1711717 D)717717l
答案:C
评析:在子函数fun中,sl为字符串w的起始地址,s2为字符串的结束地址(字符'\O'除外),当执行循环结束循环,w="1711717"。
(31)下面程序
main()
{ int x=100,a=10,b=20,okl=5,ok2=0;
if(a<b)
if(b!=15)
if(10k1) x=l;
else i"oL2)x。10;
X=-1;
Printf(%d\n",x);
}
的输出是________。
A)-1 B)0 c)1 D)不确定的值
答案:A
评析:第一个判断值为真,过渡到下一个判断,第二个判断为真,过渡到第三个判断……如此循环,在打印输出语句的前一行,程序给变量x赋了值,为.1,所以,无论前期如何变化,最后的x值依然为-1。
(32)下面程序
main()
{
int x=32:
printf("%d\n",x=x<<1);
}
的输出是________。
A)100 B)160 C)120 D)64
答案:D
评析:<<是c语言中规定的左移运算符,例如,a=a<<2,这个语句即是将a的二进制数左移两位,左移一位相当于该数乘于2,左移两位相当于该数乘以2的2次方。所以,x<<1=32.2=64。
(33)设有以下定义和语句,输出的结果是(用small模式编译,指针变量占2个字节)_________。
struct date
{
long *cat;
struct date *next;
double dog;
}too;
printf("%d",sizeof(too));
A)20 B)16 C)14 D)12
答案:D
评析:sizeof函数计算已知类型所占的字节数。结构体变量所占内存长度是各成员占的内存长度之和。指针变量占2个字节,所以cat和*next各占2个字节;double型占8个字节,故too共占12个字节。
(34)以下程序的输出结果是_________。
#include<stdio.h>
#define FUDGE(y) 2.84+y
#define PR(a)printf ("%d",(int)(a))
#define PRINT l(a) PR(a);putchar('\n')
main()
{ intx=2;
PRINTl(FUDGE(5)*x);
}
A)ll B)12 C)13 D)15
答案:B
评析:在程序中如果有带实参的宏,则按#define命令行中指定的字符串从左到右进行置换,如果串中包含宏中的形参,则将程序语句中相应的实参代替形参。将实参带入已经定义的宏中,可以得出答案灯"12"。
(35)以下程序段给数组所有的元素输入数据,请选择正确答案填入:
#include<stdio.h>
main()
{
int a[10],i=O;
while(i<l0)scanf("%d",________);
:
:
}
A)a+(i++) B)&a[i+l] C)a+i D)&a[++I]
答案:A
评析:a就是数组a的首地址,而a+x是数组中第x个元素的地址,。所以在四个选项中,选项B和c只能输入一个数据,选项D不能给a[O]输入数据,只有A可以完成给数组所有的元素输入数据的任务。
(36)以下对枚举类型名的定义中正确的是________。
A)enum a={one,two,three}; B)enum a{one=9,two=-1,three};
C)enum a={"one","two","three"}; D)enum a{"one","two","three"};
答案:B
评析:声明枚举类型用enum开头。例如:enum weekday(sun,mon,tue,wed,thu,fri,sat);
说明:1、在c编译中,对枚举元素按常量处理,同时可以改变他们的值。2、枚举值可以用来做判断比较。3、一个整数不能直接赋给一个枚举变量。
(37)字符(char)型数据在微机内存中的存储形式是________.
A)反码 B)补码
C)EBCDIC码 D)ASCII码
答案:D
评析:将一个字符常量放到一个字符变量中,实际上并不是把该字符本身放到内存单元中去,而是将该字符的ASCII码值放到存储单元中。
(38)下面程序的输出是________。
typedef union
{ long x[2];
int y[4];
char z[8];
}MYTYPE;
MYTYPE them;
main()
{ printf("%d\n",sizeof(them));}
A)32 B)16 C)8 D)24
答案:C
评析:sizeof(x)是一个标准c函数,它的返回值是x型的数据结构占用的内存字节数。题目中定义了一个共用体,共用体变量在内存中所占的长度等于最长的成员的长度。
(39)有以下程序,程序运行后的输出结果是_________。
Int f(intb[][4])
{ int I,J,s=O;
for(j=00<4;j++)
{
I=j;
if(I>2)i=3-j;
s+=b[i][j];
}
return s:
}
main()
{
int a[4][4]={{1,2,3,4},{O,2,4,6},{3,6,9,12},{3,2,1,0}};
printf("%d\n",f(a));
}
A)22 B)ll C)18 D)16
答案:D
评析:本题通过函数调用对数组a[0][0]、a[1][l]、a[2112]、a[0][3]进行求和,然后用return语句返回s的值。
(40)不能把字符串:Hello!赋给数组b的语句是_________。
A)charb[10]={'H','e','1','l','0','!'};
B)char b[10]={'h','e','1','l''O','!'};
C)charb[10];strcpy(b,"Hello!");
D)char b[10]="Hello!";
答案:B
评析:在c语言中,大写字母和小写字母被认为是两个不同的字符,因此,"hello!"和"Hello!"是两个不同的字符串。
(41)下面程序的输出是_________。
main()
{ int x=3,y=6,a=0;
while(x++!=(y-=1))
{ a+=1;
if(y<x)break;
}
primf("x=%d,y=%d,a=%d\n",x,y,a);
}
A)x=4,y=4,a=1 B)X=5,y=5,a=1
C)x=5,y=4,a=3 D)x=5,y=4,a=l
答案:D
评析:注意的是x++中x值的引用时,这里应当是先引用,后自加,具体执行过程如下:
第一次while循环:条件为真,执行a=a+l=l;此时,x的值已为4,判断y<x不成立,继续执行循环;
第二次while循环:条件为假,此时x的值已为5,退出while循环,执行printf。
(42)若有程序:
fun(int a,int b)
{
static int c=O:
c+:a+b:
return C;
}
main()
{
int x=5,y=3,z=7,r;
r=fun((y,x+y),z);
r=fun(x,y);
printf("%d\n",r);
}
上面程序的输出结果是__________。
A)23 B)15 C)19 D)18
答案:A
评析:stoic声明的外部变量只限于被本文件引用,而不能被其他文件引用。用static来声明一个变量的作用有:①对局部变量用static声明,则为该变量分配的空间在整个程序执行期间始终存在;②全部变量用static声明,则该变量的作用域只限于本文件模块(即被声明的文件中)。调用第一个fun,其两个实参的值为(3,5+3)与7即8与7,在函数fun执行结束返回15。第二次调用fun时,由于stat~为静态类型,其值保留,执行fun(5,3)后,其返回值为23,故选A。
(43)下面程序的输出是________。
main()
{char*s="12134211";
int vl=0,v2=0,v3=0,v4=0,k;
for(k=0;s[k];k++)
switch(s[k])
{ default:v4++;
case'l':vl++;
case'3':v3++;
case'2':v2++;
}
printf("v1=%d,v2=%d,v3=%d,v4=%d\n",v1,v2,v3,v4);
}
A)vl=4,v2=2,v3=l,v4=l B)vl=4,v2=9,v3=3,v4=l
C)vl=5,v2=8,v3=6,v4=l D)vl=8,v2=8,v3=8,v4=8
答案:C
评析:当switch后面括弧内的表达式的值与某一个case后面的常量的表达式的值相等时,就执行此caSe后面的语句,若所有的case中的常量表达式的值都没有与表达式的值匹配的,就执行default后面的语句。
(44)下面程序的输出是_________。
main()
{ int k=11;
printf("k=%d,k=%o,k=%x\n",k,k,k);
}
A)k=l1,k=12,k=l1 B)k=ll,k=13,k=13
C)k=l1,k=013,k=0xb D)k=l1,k=13,k=B
答案:D
评析:在C语言格式字符的输出中,"%d"是以带符号的十进制形式输出整数;"%0"是以8进制无符号形式输出整数(不输出前导符O);"O/ox"是以16进制无符号形式输出整数(不输出前导符0x)。
(45)下面程序段中c的二进制值是__________。
char a=3,b=6,c;
c=a^b<<1:
A)00001011 B)00001111 C)00011110 D)00011100
答案:B
评析:c语言提供六种位运算符,按优先级由高到低的顺序分别为:取反(~)、左移((<)和右移(>>)、按位与(&)、按位异或(八)、按位或(I)。所以表达式c=aAb<<l先运算b<<l得二进制值为00001 100,再运算aA00001 100,最后得二进制值00001ll1。B
评析:c语言提供六种位运算符,按优先级由高到低的顺序分别为:取反(~)、左移((<)和右移(>>)、按位与(&)、按位异或(八)、按位或(I)。所以表达式c=aAb<<l先运算b<<l得二进制值为00001 100,再运算aA00001 100,最后得二进制值00001ll1。
(46)以下叙述中正确的是__________。
A)C语言比其他语言高级
B)C语言可以不用编译就能被计算机识别执行
C)C语言以接近英语国家的自然语言和数学语言作为语言的表达形式
D)C语言出现的最晚,具有其他语言的一切优点
答案:C
评析:计算机语言分为低级语言、汇编语言和高级语言,c语言属于高级语言,但并不是说c语言比其他语言高级,所以选项A错误;除了低级语言外,其他各种语言都必须编译成能被计算机识别的二进制数才能执行,选项B错误;C语言出现从1972年到1973年间,并不是出现最晚的语言,所以选项D也是错误的。
(47)下列可用于C语言用户标识符的一组是__________。
A)void define WORD B)a3_b3 _123 Car
C)For -abc IFCase D)2a DO sizeof
答案:B
评析:c语言规定标识符只能由字母、数字和下划线3种字符组成,且第一个字符必须为字母或下划线,所以排除c和D。c语言还规定标识符不能为c语言的关键字,从而选项A(void是关键字)是错误的。
(48)fgetc函数的作用是从指定文件读入一个字符,该文件的打开方式必须是________。
A)只读 B)追加 C)读或读写 D)以上均正确
答案:D
评析:fgetc函数是指从指定的文件读入一个字符,该文件必须是以读或读写方式打开的。电etc"函数的调用形式为:ch=fgetc(fp);。
(49)请选出正确的程序段_________。
A)int*p B)int*s,k;
Scanf(""%d"",p); *s=100;
…… ……
C)int*s,k; D)int*s,k;
Char *p,c; char *p,e;
s=&k: s=&k
p=&c; p=&c;
*p='a'; s=p;
…… *s=l;
……
答案:C
评析:本题的A和B犯了一个同样的错误,即指针变量p定义后并没有指向具体的变量,因此不能进行赋值操作。另外,在选项D中,s是int指针变量,p是char型指针变量,所指向的内存单元所占用的字节数是不同的,因而不能将字符指针变量p的值赋给整型指针变量s。
(50)若有下面的说明和定义,则sizeof(struct aa)的值是__________。
struct aa
{
int rl;double r2;float r3:
union uu{char u1[5];long u2[2]}ua;
}mya;
A)30 B)29 C)24 D)22
答案:D
评析:结构体变量所占内存长度是各成员占的内存长度之和,每个成员分别占有自己的内存单元;共用体变量所占的内存长度等于最长的成员的长度。结构体变量aa中,成员r1占2个字节,r2占8个字节,r3古4个字节,共用体ua占8个字节,所以共占用2+8+4+8=22个字节。
二、填空题(每空2分,共40分)
请将每一个空的正确答案写在答题卡的【1】至【20】序号的横线上,答在试卷上不得 分。
(1)在先左后右的原则下,根据访问根结点的次序,二叉树的遍历可以分为三种:前序遍 历、 【1】 遍历和后序遍历。
答案:【1】中序
评析:在先左后右的原则下,根据访问根结点的次序,二叉树的遍历可以分为三种:前序遍历、中序遍历和后序遍历。
前序遍历是指在访问根结点、遍历左子树与遍历右子树这三者中,首先访问根结点,然后遍历左子树,最后遍历右子树;并且遍历左、右子树时,仍然先访问根结点,然后遍历左子树,最后遍历右子树。
中序遍历指在访问根结点、遍历左子树与遍历右子树这三者中,首先遍历左子树,然后访问根结点,最后遍历右子树;并且遍历左、右子树时,仍然先遍历左子树,然后访问根结点,最后遍历右子树。
后序遍历指在访问根结点、遍历左子树与遍历右子树这三者中,首先遍历右子树,然后访问根结点,最后遍历左子树;并且遍历左、右子树时,仍然先遍历右子树,然后访问根结点,最后遍历左子树。
(2)结构化程序设计方法的主要原则可以概括为自顶向下、逐步求精、 【2】 和限制使用goto语句。
答案:【2】模块化
评析:结构化程序设计方法的主要原则可以概括为自项向下、逐步求精、模块化和限制使用goto语句。
自顶向下:程序设计时,应先考虑总体,后考虑细节;先考虑全局目标,后考虑局部目标。不要一开始就过多追求众多的细节,先从最上层总目标开始设计,逐步使问题具体化。
逐步求精:对复杂问题,应设计一些子目标作过度,逐步细化。
模块化:一个复杂问题,肯定是由若干稍简单的问题构成。模块化是把程序要解决的总目标分解为分目标,再进一步分解为具体的小目标,把每个小目标称为一个模块。
限制使用goto语句。
(3)软件测试是保证软件质量的重要手段,而软件测试的主要和重要的测试方法是通过测 试数据和 【3】 的设计来实现。
答案:【3】测试实例
评析:进行软件测试时,应精心设计测试实例和选择测试数据,以对系统进行全面测试。
(4)数据库系统的三级模式分别为 【4】 模式、内部级模式与外部级模式。
答案:【4】概念 或 概念级
评析:数据库系统在其内部具有三级模式及二级映射,三级模式分别是概念级模式、内部级模式和外部级模式。
概念模式是数据库系统中全局数据逻辑结构的描述,是全体用户(应用)公共数据视图。
内模式又称物理模式,它给出了数据库物理存储结构与物理存取方法,如数据存储的文件结构、索引、集簇及hash等存取方式与存取路径,内模式的物理性主要体现在操作系统及文件级上,.它还未深入到设备级上(如磁盘及磁盘操作)。
外模式也称子模式或用户模式,它是用户的数据视图,也就是用户所见到的数据模式,它由概念模式推导面出。
(5)数据字典是各类数据描述的集合,它通常包括5个部分,即数据项、数据结构、数据流、 【5】 和处理过程。
答案:【5】数据存储
评析:数据字典是各类数据描述的集合,它通常包括5个部分,即数据项,是数据的最小单位;数据结构,是若干数据项有意义的集合;数据流,可以是数据项,也可以是数据结构,表示某一处理过程的输入或输出;数据存储,处理过程中存取的数据,常常是手工凭证、手工文档或计算机文件;处理过程。
(6)下面程序的输出是 【6】 。
main()
{int arr[10],i,k=O:
for(i=0;i<10;i++)
arr[i]=i;
for(I=1;i<4;i++)
k+=arr[I]+i;
printf("%d\n",k);}
答案:【6】12
评析:本题通过第一个for循环将数组arr[O]-arr[9]分别赋值为0-9,通过第二个for循环的三次循环累加,求出结果为12,具体分析如下:
i=l:k=0+arr[1]+l即k=2:
i=2:k=2+arr[2]+2即k=6:
i=3:k=6+arr[3]+3即k=12;
(7)若a=10,b=20,则表达式!(a<b)的值是 【7】 。
答案:【7】0
评析:已知a=10,b=20,所以逻辑表达式a<b的值为true,即为1,在这个表达式前面有一个逻辑运算符!,表示反操作,所以整个语句的值应当为false,即为0。
(8)有以下程序:
int fa(int x){return x*x;}
int fb(int x){return x*x*x;}
int f(int(*f1)(),int(*f2)(),int x)
{return f2(X)-n(x);}
main()
{int i;i=f(fa,fb,2);printf("%d\n",i);}
程序运行后,输出结果是 【8】 。
答案:【8】4
评析:在主函数中调用函数f,函数f有三个参数,形参f1与f2分别是两个指向函数的指针。在f中执行r2(x)-f1(x),实际上是执行了fb(2).fa(2),故执行i=(fa,fb,2)后i的值为2^3-2^2=4。
(9)下面程序的输出是 【9】 。
main()
{enum em{eml=3,em2=1,em3};
char*aa[]={"AA","BB","CC","DD"};
primf("%s%s%s\n",aa
,aa
,aa
);
}
答案:【9】DDBBCC
评析:c语言对枚举的定义规定:在枚举中声明的各个枚举元素,如果没有明确指出某个枚举元素的值,它的上一个元素存在并有明确值的情况下,这个枚举元素的值为其上一个元素的值+1。
在本题中,没有明确说明枚举元素em3的值,则em3=em2+l=1+l=2,进而可知,在printf()打印函数中,要打印的数组元素是aa[3]、aa[1]、aa[2],因此最后的打印结果应当为"DDBBCC"。
(10)若想通过以下输入语句使a=5.0,b=4,c=3,则输入数据的形式应该是 【10】 。
int b,c;float a;
scanf("%£%d,c=%d",&a,&b,&c)
答案:【10】5.0,4,c=3
评析:scanf(格式控制,地址表列),如果在"格式控制"字符串中除了格式说明以外还有其它字符,则在输入数据时应输入与这些字符相同的字符。所以此题中输入数据的形式是5.0;4,c=3。
(11)下列程序的输出结果是 【11】 。
int t(int x,int y,int cp,int dp)
{ cp=x*x+y*y;
dp=x*x-y*y;
}
main()
{ int a=4,b=3,c=5,d=6;
t(a,b,c,d);
printf("%d%d\n",c,d);
}
答案:【ll】5 6
评析:本题中a,b,c,d是实参,x,多,cp,dp是形参。c语言规定,实参变量对形参变量的数据传递是"值传递",即单向传递,只由实参传给形参,而不能由形参传回来给实参。在内存中,实参单元与形参单元是不同的单元。在调用函数时,给形参分配存储单元,并将实参对应的值传递给形参,调用结束后,形参单元被释放,实参单元仍保留并维持原值。因此,程序的输出结果是5 6。
(12)下面程序的输出结果是 【12】 。
char b[]="ABCD";
main()
{
char b[30];
strcpy(&b[0],"GH");
strcpy(&b[1],"GH");
strcpy(&b[2],"GH");
printf("%s\n",b);
}
答案:【12】GGGH
评析:由于在函数main中定义了数组变量b,其将屏蔽全局变量b。对于一维数组变量,其值为一常数,等于数组首元素地址。strcpy(&b[0],"GH"),是将字符串。"GH"复制到数组b中从首元数开始的空间中,此是b中的字符串为"GH";strcpy(&b[1],"GH"),是将字符串。"GH"复制到数组b中从第二个元素开始的空间中,此是b中的字符串为"GH"。执行第三次strcpy函数后,b中的字符串为"GGGH"。
(13)有以下定义和语句,则sizeof(a)的值是 【13】 ,而sizeof(a.share)的值是 【14】 。
struct date
{ int day;
int mouth;
int year;
union{int sharel;
float share2;
}share;
}a;
答案:【13】10
【14】4
评析:结构体变量所占内存长度是各成员占的内存长度之和。每个成员分别占有其自己的内存单元。int占2个字节,float占4个字节,共用体变量所占的内存长度等于最长的成员的长度。所以,sizeof(a.share)的值是4,sizeof(a)的值是2+2+2+4=10。
(14)下述函数用于统计一行字符中的单词个数,单词之间用空格分隔。
Word_num(str)
char str[];
{int i,num=O,word=O;
for(i=0;str[i]!= 【15】 ;i++)
if( 【16】 =='')word=0;
else if(word==0)
{
word=l;
【17】 ;
}
return(num);
}
答案:【15】'\0'或0或NULL
【16】str[I]
【17】num++或num=num+l或num+=1
评析:观察题目要求,可以知道以下几点:
①for循环的结束条件应当是:str[i]已是字符串的最后一个字符;
②strⅢ代表字符串str中的第i+1个字符;
③整型变量num的值是要记录的单词的个数。
c语言中规定字符串的最后一个字符是一个隐含的字符串结束符"\0",所以在题中第一个空中应填写"\0";题中第二个空应填写"str[i]",以判断当前位置的字符是否为空格;题中第三个空中应当填写"num++",通过变量num的加l累加得到字符串中的单词个数。
(15)有一个已排好序的数组,今输入一个数,要求按原来的顺序规律将它插入到数组中。算法是:假设排序顺序是从小到大,对输入的数,检查它在数组中哪个数之后,然后将比这个数大的数顺序后移一个位置,在空出的位置上将该数插入。请在程序中的空白处填上一条语句或一个表达式。
#defineN 100
main()
{ float a[N+1],x;
inti,p;
for(i=0;i<N;i++)
scanf("%f",&a[I]);
scanf("%f",&x);
for(I=0,p=N;i<N;i++)
if(x<a[I])
{ 【18】 ;
break;}
for(i=N-1; 【19】 ;I--)
a[I+1]=a[I];
a[p]_x;
for(i=0; 【20】 ;i++)
{ primf("%8.2f",a[i]);
if(i%5==O)
printf("\n");
}
}
答案:【18】p=i;
【19】i>=p
【20】i<=N
评析:本题主要考查了插入排序。由于程序中的数组在开始已经按从小到的大顺序排好。在插入时,首先要查到第一个大于待插入数的数组下标,即当待插入元素小于数组中当前元素时,记下数组的当前下标p,并结束循环。故第一空目的是为了记下数组下标,应填p=i;插入排序的第二部是将大于待插入元素的所有元素都向后移动一位,故在循环时,要从最后一个元素到第p个元素都要后移一位,因此第二空应埴i>=p。最后一个循环是将N+1个元素都输出,故最后一空应为i<=N。(注:本题有多种答案,以上仅提供一种)