大连理工大学C语言模拟题机房题库单选、判断、填空(分章节 - 共十一章)

更新时间:2023-11-30 23:22:01 阅读量: 教育文库 文档下载

说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。

1111111111111111111111111111111111111111111111111111111111111111111111111111 第一部分 注意事项

1. 请对照《课件》和《教材》进行练习。

2. 熟悉键盘,注意竖杠“|”和反斜杠“\\”的位置,请在西文状态下输入。

3. 单选题、判断题和填空题要会验证。当输入汉字时,可能输入提示框是灰色的,再按一次中英文切换键即可。

4. 程序填空题不能删除注释/*****FILL*****/,但必须删除标记符号_____,否则编译通不过。如,for(i=10; ____; i++)。

5. 程序改错题不能删除注释/*****ERROR*****/,仅在其下一行进行修改。

6. 程序填空题和程序改错题存盘即可。但最好编译运行一下,编译时会自动存盘。编译帮助检查语法错误,运行帮助检查逻辑错误。

7. 程序设计题不能删除注释/****BEGIN*****/和/****END*****/,只能在两个标记符之间编写程序。必须保证编译、链接、运行都正确。

8. 以上程序题中不能更改程序结构和其它位置的程序代码,可以忽略其它程序位置的警告。

9. 如果VC发生死机(见图,可用按钮都变成灰色),请结束VC进程,再继续答题或重答。 结束VC进程的方法:

先进入“任务管理器”;再选下面一种方法操作:

方法1:选择“应用程序”标签,选中“VC任务”,按“结束任务” 。 方法2:选择“进程”标签,选中“MSDEV.EXE”,按“结束进程” 。

10. 提交试卷并看到成绩后再离开。

11.出现问题立即请示监考老师。

12.请记住几个常用的函数。

数学函数:sin(),cos(),tan(),log(),exp(),pow(),sqrt(),abs(),fabs() 字符串函数:strcat(),strcpy(),strcmp(),strlen(),strlwr(),strupr() 输入输出函数:printf(),scanf(),putchar(),getchar(),puts(),gets(), fopen(),fclose(),fprintf(),fscanf(),feof() 其它实用函数:rand(),exit()

第二部分 概念题

第1章 概述

1. C程序是的基本组成单位是_______. 函数

2. C语言的程序结构分为______、选择结构和循环结构。顺序结构

第3章 数据类型、运算符和表达式

一、单选题

1. 已知大写字母A的ASCII码值是65,小写字母a的ASCII码是97,则用八进制表示的字符常量'\\101'是(A)。 A、字符A B、字符a C、字符e

D、非法的常量

2. 下列关于单目运算符++、--的叙述中正确的是(D)。

A、它们的运算对象可以是int型变量,但不能是double型变量和float型变量 B、它们的运算对象可以是任何变量和常量

C、它们的运算对象可以是char型变量和int型变量,但不能是float型变量 D、它们的运算对象可以是char型变量、int型变量和float型变量

3. 执行下列程序后,其输出结果是(D)。 main() {int a=9; a+=a-=a+a;

printf(\} A、18 B、-9 C、9 D、-18

4. 下述正确的C语言常量是:(C). A、E2 B、5.0E C、3e-3 D、1.5E2.5

5. 若有定义:int a=7;float x=2.5,y=4.7; 则表达式x+a%3*(int)(x+y)%2/4的值是(D)。 A、0.000000

B、2.750000 C、3.500000 D、2.500000

6. 下面四个选项中,均是不合法的用户标识符的选项是(D)。 A、float la0 _A B、A P_0 do C、_123 temp int D、b-a goto int

7. 表达式18/4*sqrt(4.0)/8值的数据类型为(A)。 A、double B、float C、int D、不确定

8、以下字符中不是转义字符的是(A)。 A、'\\c' B、'\\b' C、'\\\\' D、'\\a'

9. 设a=12,且a定义为整型变量。执行语句a+=a-=a*=a;后a的值为(A)。 A、0 B、144 C、132 D、12

10.下列变量说明语句中,正确的是(D)。 A、char a;b;c; B、char:a b c; C、int x;z; D、int x,z;

11.设以下变量均为int类型,则值不等于7的表达式是(A)。 A、(x=6,x+1,y=6,x+y) B、(x=y=6,x+y,y+1) C、(y=6,y+1,x=y,x+1) D、(x=y=6,x+y,x+1)

12.若变量均已正确定义并赋值,以下合法的C语言赋值语句是(C)。 A、x+n=I; B、x==5; C、x=n/2.5;

D、5=x=4+1;

13.下述错误的C语言常量是:(C). A、0xf B、5. C、090 D、.25

14. 字符串\的长度是:(C). A、3 B、11 C、7 D、5

15. 设变量a是整型,f是实型,i是双精度型,则表达式10+'a'+i*f值的 数据类型为(A)。 A、double B、不确定 C、int D、float

16. 下列语句的结果是(B)。 main() { int j; j=3;

printf(\printf(\}

A、3,3 B、4,4 C、3,4 D、4,3

17. 假定有以下变量定义: int k=7,x=12;

则能使值为3的表达式是:(A) A、(x%=k)-(k%=5) B、x%=(k-k%5) C、x%=k-k%5 D、x%=(k%=5)

18.下列数据中,为字符串常量的是(D)。 A、'A'

B、How do you do.

C、$abc D、\

19.以下所列的C语言常量中,错误的是(B)。 A、0xFF B、1.2e0.5 C、2L D、'\\72'

20.下列表达式中,可作为C合法表达式的是(D)。 A、3.0%2 B、3=2=1=0 C、[3,2,1,0] D、(3,2,1,0)

21.当x为偶数或奇数时(0除外),其值都为0的表达式是(C) A、(x/2*2-x)==0 B、x%2==0 C、!x!=0 D、!(x%2)

22.sizeof(float)是(C)。?501 A、一个浮点表达式 B、一个不合法的表达式

C、函数调用结果是一个整型表达式。 D、一种函数调用

23.下列数据中属于\字符串常量\的是(B)。 A、'A' B、\C、ABC D、'ABC'

二、判断题

1. 在C语言中,各种类型的整型数据在内存中都占2个字节。F 2. 在C程序中,%作为运算符时,是只能用于整数运算。T

3. 若a和b类型相同,在计算了赋值表达式a=b后,b中的值将放入a中,而b中的值不变.T 4. a=(b=4)+(c=6) 是一个合法的赋值表达式。T

5. 若有 int i=10,j=2;则执行完i*=j+8;后ⅰ的值为28。F 6. 表达式 (j=3,j++) 的值是4. F

7. 若i =3,则printf(\输出的值为 -4。F

三、填空题

1. 下列语句输出的结果是_____,unsigned int b=65535;printf(\-1

2. 下列语句输出的结果是_____,int a=-1;printf(\在vc环境下) ffffffff 3.在C语言中,long类型数据占_____个字节, short类型数据占_____个字节.4,2 4. 若有定义:char c='\\010'; 则变量C中包含的字符个数为_____. 1 5.已知a=-13,b=6, a%b的十进制数值为_____.-1 6. int x; x=-3+4%-5*3, 则x的值为_____.9

7.设x和y均为int型变量,且x=1,y=2,则表达式1.0+x/y的值为_____. 1.0

8. 若有定义:int a=10,b=9,c=8;接着顺序执行下列语句后,变量c中的值是 _____ . c=(a-=(b-5)); c=(a)+(b=3); 9

9. 设x的值为15,n的值为2,则表达式x%=(n+=3)运算后x的值是_____. 0

10.已知 float i=5.6;int a;写出语句 a=(int)i; 执行后变量 i 的值是_____.5.6 11.设x=2.5,a=7,y=4.7,算术表达式x+a%3*(int)(x+y)%2/4的值为_____.2.5 12.若int x=6;则x+=x-=x*x表达式最后x的值是_____. -60 13. 设有int x=11,则表达式(x++ * 1/3)的值是_____。3 14. 执行下列语句的结果是_____.4,4 a=3;

printf(\printf(\15. 设a、b、c为整型数, 且a=2、b=3、c=4, 则执行完以下语句: a*=16+(b++)-(++c); 后,a的值是 _____. 28

16.以下程序的输出结果为_____. 9,10

#include \17.int x=2;z=x++-1; 则x的值为_____. 3

第4章 输入输出

一、单选题

1. 下列程序段的输出结果为(C)。

float k=0.8567; printf(\A、85.6% B、85.6%% C、85.7% D、.857

2. 下面的scanf函数输入数据,使得a=10,b=15,s1='S',s2='s',x1=1.5,x2=-3.75,x3=67.8, 正确的键盘输入方法是(A). (用\表示回车,U表示空格) main() {int a,b;

float x1,x2,x3; char s1,s2;

scanf(\}

A、10UUU15Ss1.5U-3.75U+1.5U67.8[CR] B、10UUU15USUs1.5U-3.75U+1.5U67.8[CR] C、10UUU15USUsU1.5U-3.75U+1.5U67.8[CR] D、10UUU15Ss1.5U-3.75U+1.5,67.8[CR]

5. 打印语句printf(\在屏幕上正确的输出形式是(C). A、sTUDENDS B、TUDENTS C、STUDENT D、sTUDENTS

6. 根据下面的程序,使i=123,c1='A',c2='B'哪一种是正确的键盘输入方法(C). (规定用[CR]表示回车,U表示空格) main() {

int i;

char c1,c2;

scanf(\}

A、123AUB[CR] B、123UAUB[CR] C、123AB[CR] D、123[CR]AB[CR]

7. 设:long w=65535,t=7654321;

根据下面的输出结果,正确的程序段是(C). w=65535,t=7654321 end

A、printf(\B、printf(\C、printf(\D、printf(\

8. 已定义float x=1.25,y=3.37;

根据下面的输出结果,正确的输出语句是(C). y+x=4.62,y-x=2.12

A、printf(\B、printf(\C、printf(\D、printf(\

9. 根据下面的程序,使a=123,c1='o',c2='k'哪一种是正确的键盘输入方法?(B)。 (规定用字符串[CR]表示回车,U表示空格) main() {int a;

char c1,c2;

scanf(\}

A、123UoUk[CR] B、123ok[CR] C、123Uok[CR] D、123oUk[CR]

10.以下程序的输出结果是(D)。 main()

{float x=3.6; int i; i=(int)x;

printf(\}

A、x=3.600000,i=4 B、x=3 i=3.600000 C、x=3,i=3

D、x=3.600000,i=3

11.下面程序的正确输出结果是(A).(规定用U表示空格) main() {

float x=5.783,y= -10.2345;

printf (\}

A、x=5.78UUUU,y=-10.23UU B、x=5.78,y=-10.23 C、5.78,-10.23

D、x=UUUU5.78,y=UU-10.23

12.用下面的scanf函数输入数据,使得i=10,k=15选择正确的键盘输入方法(B). (用\表示回车,U表示空格) main() {int i,k;

scanf(\}

A、i=10[CR]k=15[CR] B、i=10,k=15[CR] C、10U15[CR] D、10,15[CR]

二、判断题

1. C语言的输入功能是由系统提供的输入函数实现的.T 2. 格式字符%o用来以十六进制形式输出整数.F 3. 格式字符%x用来以八进制形式输出整数.F

4. 格式字符%e以指数形式输出实数数字部分小数位数7位.F

5. 格式字符%g选用%e或%f格式中输出宽度较长的一种格式输出实数. F 6. 整型变量在全部范围内可以用字符格式输出. F

7. char c[6]=\表示输出的字段的宽度为3位,如果被输出的数据的位数大于3,只输出3位数.F

8. char c[6]=\表示输出的字段的宽度为3位,如果被输出的数据的位数大于3,按实际位数输出.T

9. C语言程序中输入一个中间带有空格的字符串时,可以用scanf函数. F 10.C语言程序中输入一个中间带有空格的字符串时,只能用gets函数. T

三、填空题

1. getchar()函数只能接收一个_____. 字符

第5章 逻辑运算与选择结构

一、单选题

1. C语言的if语句中,用作判断的表达式为(A)。 A、任意表达式 B、算术表达式 C、逻辑表达式 D、关系表达式

2. 以下程序的输出结果是:(A) main() {int m=5;

if(m++>5) printf(\else printf(\ } A、6 B、5 C、7 D、4

//后置++,--在离开下面的运算符时,后置运算完成: 1)表达式语句的; 2)逗号表达式的, 3)条件表达式的?

4)逻辑表达式的&&或||

5)(if switch for while)的控制表达式 6)for的三个表达式中的任意一个

3. 已知键盘输入a=4,b=3,下面程序输出的结果是(C). main()

{ int a,b,s;

scanf(\ s=a;

if(a

printf(\} A、9 B、13 C、16 D、15

4. 若给定条件表达式(m)?(a++):(a--),则其中表达式m(B)。 A、和(m==0)等价

B、和(m!=0)等价 C、和(m==1)等价 D、和(m!=1)等价

5. 下列程序段的输出结果为(B)。

int a=7,b=9,t; t=a*=a>b?a:b; printf(\A、49 B、63 C、7 D、9

6. int a=1,b=2,c=3; if(a>c)b=a;a=c;c=b;则c的值为(C)。 A、1 B、3 C、2

D、不一定

7. 执行下面程序段后,b的值为(A). int s=35; char t='A'; int b;

b=((s&&4)&&(t<'a')); A、1 B、3 C、2 D、0

8. 若k是整型,则以下程序段的执行结果是:(B) k=-3;

if(k<=0) printf(\ else printf(\A、####

B、有语法错误,无结果 C、&&&& D、####&&&&

9. 设x,y,z,t均为整型变量,则执行以下语句后,t的值为:( B) x=y=z=1;

t=++x||++y&&++z; A、0 B、1 C、2

D、不定值

10.如果int a=2,b=3,c=0,下列描述正确的是( B )。 A、a&&b>c的结果为假

B、!a!=(b!=c)表达式的值为1 C、a||(b=c)执行后b的值为0

D、a>b!=c和a>(b!=c)的执行顺序是一样的

11.已知键入a=4,b=3,执行下面程序输出的结果是(B). main()

{ int a,b,s;

scanf(\ s=a;

if(a>b) s=b; s=s*s;

printf(\} A、13 B、9 C、16 D、15

12.执行下面程序段后,i的值是(A). int i=10; switch(i)

{case 9: i+=1; case 10: i--; case 11: i*=3; case 12: ++i; } A、28 B、10 C、9 D、27

13.逻辑表达式!(2-1)&&x||0的值是(B) A、1 B、0 C、3 D、2

14.int a=1,b=2,c=3; if(a>b)a=b; if(a>c)a=c; 则a的值为(C)。 A、3 B、2 C、1

D、不一定

15.若x=2,y=3则x||y的结果是(C)。 A、3 B、0 C、1 D、2

16.针对下列程序段回答问题(B). for(t=1;t<=100;t++) {

scanf(\ if(x<0) continue; printf(\}

A、x>=0时什么也不输出

B、最多允许输出100个非负整数 C、printf函数永远也不执行 D、当x<0时整个循环结束

17.下列运算符优先级最低的是(A). A、= B、+ C、! D、&&

18.逻辑表达式3<2||-1&&4>3-!0的值为:(A) A、1 B、3 C、0 D、2

19.下列运算符中是C语言关系运算符的是(C)。 A、& B、~ C、!= D、!

二、判断题

1. 运算符的级别由高向低依次为!->算术运算符->关系运算符->逻辑运算符->赋值运算符.T

2. 在逻辑运算符中的运算级别由高向低依次为 &&->||->!。F 3. 若a=3,b=2,c=1 则关系表达式\的值为\真\。T 4. 逻辑表达式-5&&!8的值为1.F

5. 逻辑表达式4>2&&1||5<3-!0的值为1.T

6. 设d=1,e=2,f=3,则逻辑表达式!(d+e)+f&&e+f*2的值为0.F

7. 设x=1,y=2,z=3,则逻辑表达式x-y>z&&y!=z的值为0.T 8. 设u=1,v=2,w=3,则逻辑表达式u||v-w&&v+w的值为0.F 9. 设g=1,h=2,k=3,则逻辑表达式k+g||!h&&k-h的值为0。F 10.已知a=3,b=4,c=5,则逻辑表达式!(a>b) && !c||1的值为1.T 11.已知a=3,b=4,c=5.则逻辑表达式a+b>c && b==c值为0.T

12.已知a=3,b=4,c=5,则逻辑表达式!(a+b)+c-1 && b+c/2的值为0.F

13.已知x=2,y=2, 执行分支语句 if(x==y) y=1; else y=-1;后,y=-1. F 14.下面程序段的输出结果为A。F int i=20; switch(i/10) {

case 2:printf(\ case 1:printf(\}

15.求解表达式max=(a>b)?a:b的步骤是,先求解条件表达式(a>b),再根据它的值将a或b赋给max.T

16.条件表达式x?'a':'b'中,若x=0时,表达式的值为'a'.F 17.已知a=4,b=2,c=3,d=5,表达式a>b?a:c

18.已知a=1,b=2,c=3,d=4,则条件表达式a>b?a:(c>d?c:d)的值为4.T

19.语句if(a>b) printf(\可以用条件表达式a>b?a:b取代.F

20.语句if(a>b) printf(\可以用语句 printf(\取代.T

三、填空题

1. C语言表达式5>2>7>8的值是_____.0

2. C语言表达式!(4>=6)&&(3<=7)的值是_____. 1

3. x=5,y=8时,c语言表达式5-2>=x-1<=y-2的值是_____.1 4. 设x=2&&2||5>1,x的值 为_____. 1

5. 设a=3,b=4,c=4,则表达式a+b>c&&b==c&&a||b+c&&b==c的值为_____. 1 6. 设x=62,表达式x>=60&&x<70||x==1的值为_____.1 7. 已知a=12,写出表达式 0

8. 已知 a=10,b=15,c=1,d=2,e=10,则表达式a++&&e++&&c++的值为_____. 1 9. 执行下列语句后, b的十进制值是_____. 1

int x=240,y=15,b; char z='A'; b=(( x && y ) && ( z < 'a' ));

10.设a,b,c,t为整型变量,初值为a=3,b=4,c=5,执行完语句t=!(a+b)+c-1&&b+c/2 后,t的值是_____. 1

11.int x=2,y=3,z=4; 则表达式x+y>z&&y==z的值为_____.0 12.int x=2,y=3,z=4; 则表达式x+y&&(x=y)的值为_____.1

13.当a=1,b=2,c=3时,执行以下程序段后b=_____.2 if (a>c) b=a; a=c; c=b; 14.已知 i=5, 写出语句 a=(i>5)?0:1; 执行后整型变量 a 的值是_____.1

第6章 循环结构

一、单选题

1. 选择结构中的条件与循环结构中循环成立的条件, 在写法上可以是任一表达式,但其值只能被判断为\真\或\假\。 哪个数作为逻辑\假\值(A)。 A、0 B、-1

C、非零的数 D、1

2. 以下for循环的执行次数是 for(x=0,y=0;(y=123)&&(x<4);x++);(C)。 A、3次

B、循环次数不定 C、4次

D、是无限循环

3. 以下程序的执行结果是(B)。 main()

{ int num = 0;

while( num <= 2 ) { num++; printf( \A、0,1,2 B、1,2,3, C、1,2,3,4, D、1,2,

4. 执行语句 for(i=1;i++<4;); 后变量 i 的值是(B)。 A、3 B、5 C、4 D、不定

5.以下描述中正确的是(C)。 A、由于 do-while 循环中循环体语句只能是一条可执行语句,所以循环体内不能使用复合语句

B、do-while 循环中,根据情况可以省略 while

C、在 do-while 循环体中,必须有能使循环退出的操作。

D、do-while 循环由do开始,用while结束,在 while(表达式)后面不能写分号

6. t为int类型,进人下面的循环之前,t的值为0 while( t=1 ) { ??}

则以下叙述中正确的是(C)。 A、循环控制表达式的值为0

D、将5个初值依次赋给a[1]至a[5]

15.以下对一维整型数组a的正确说明是(D)。 A、int a(10);

B、int n; scanf(\C、int n=10,a[n];

D、#define SIZE 10 (换行) int a[SIZE];

16.以下定义语句中,错误的是(A)。 A、int n=5,a[n]; B、int a[]={1,2}; C、char s[10]=\D、char *a[3];

17.下面叙述中不正确的是(C).

A、可以对字符型数组进行整体输入和输出. B、不可以对浮点型数组进行整体输入和输出. C、可以对整型数组进行整体输入和输出. D、字符型数组可以存放字符串.

18.下面各语句中,能正确进行赋字符串操作的语句是(B). A、char s1[5][ ]={\

B、char s2[6]={'A','B','C','D','E'}; C、char st[ ][ ]={\

D、char s[5]={'A','B','C','D','E'};

19.若有说明: int a[3][4]={0};则下面正确的叙述是(A)。 A、数组a中每个元素均可得到初值0 B、只有元素a[0][0]可得到初值0

C、数组a中各元素都可得到初值,但其值不一定为0 D、此说明语句不正确

20.若有说明 int a[3][4];则a数组元素的非法引用是(B)。 A、a[1][3] B、a[0][4] C、a[0][2*1] D、a[4-2][0]

二、判断题

1. C语言中引用数组元素的方括号可以用花括号代替.F 2. 数组的首地址一定是第一个数组元素的地址.T

3. 数组整体不参加数据处理(即不参加各种运算),参加数据处理的只能是数组的元素.T 4. 定义 int x[5],n;则x=x+n;或x++;都是正确的.F

5. 定义一维数组的形式为:类型说明 数组名[表达式],其中表达式必须是整型常量. F

6. 引用数组元素时,下标可以是整型表达式或整型常量.T 7. 引用数组元素时,数组元素下标必须是整型常量.F 8.下列程序段是否正确: F int a[10]; .... a++;

9. 若有定义 int a[10];则 for (i=0;i<=10;i++) a[i]=i;编译时无语法错误.T 10.二维数组在内存中存贮时,是按列的顺序连续存贮各元素的值.F 11.二维数组在内存中存贮时,是按行的顺序进行存储的。T 12.若有定义和语句:

int a[3][3]={{3,5},{8,9},{12,35}},i,sum=0; for(i=0;i<3;i++) sum+=a[i][2-i];则sum=21.T 13.int a[3][4]={{1},{5},{9}}; 它的作用是将数组各行第一列的元素赋初值,其余元素值为0。T

14.对于字符数为n个的字符串,其占用的内存为n+1个字节空间.T

15.如果有一个字符串,其中第十个字符为'\\n',则此字符串的有效字符为9个。F 16.设有数组定义:char array[]=\则数组 array所占的内存空间为5字节.F 17.字符串\在内存中的存储长度是7. F

18.语句 char ch[12]={\与语句 char ch[ ]=\具有不同的赋初值功能.T

19.puts 函数用来输出一个字符.F

20.gets 函数是用来输入一个字符的函数.F 21、定义char s[9];gets(s);若输入的字符串是Turbo c↙(↙代表按回车键操作) 则输入给数组s中的字符个数是7.T

22.字符处理函数strcpy(str1,str2)的功能是把字符串1接到字符串2的后面.F 23.两个字符串中的字符个数相同时才能进行字符串大小的比较.F

三、填空题

1. C语言中,数组元素的下标下限为_____. 0

2. C语言中,数组名是一个不可变的_____常量,不能对它进行加减和赋值运算. 地址 3、按内存排列顺序, 数组char a[2]中的所有元素是a[0]和_____. a[1]

4. 若有以下数组a,数组元素:a[0]~a[9],其值为 9 4 12 8 2 10 7 5 1 3 该数组的元素中,数值最小的元素的下标值是_____. 8

5. C语言中,二维数组在内存中的存放方式为按_____优先存放.行

6. static int a[3][3]={{1,2,3},{4,5,6},{7,8,9}};其中a[1][2]的值为_____. 6 7. 字符串的结束标志是_____. '\\0' 0

8. 连接字符串的函数是_____,只写函数名即可.strcat 9. 字符串比较的库函数是_____,只写函数名即可. Strcmp

10.字符处理函数strcpy(str1,str2)的功能是把字符串1接到字符串2的后面.F

第8章 函数

一、单选题

1. 以下函数的类型是(C)。 fff(float x) {

return 5; }

A、void 类型

B、与参数x的类型相同 C、int类型 D、无法确定

2. 设有如下函数 fac(int x) {

float y=1.0; return(x*y); }

则函数的类型为(A). A、int型 B、float型 C、无法确定 D、void型

3. 设有宏定义#define PI 3.14 和#define S(r) PI*r*r,则S(2)的值为(B). A、6.28 B、12.56 C、3.14 D、9.42

4. 以下正确的函数定义是(C).

A、double fun(int x, int y) { z=x+y; return z;} B、fun(x, y) { int x, y; double z; z=x/y; return z;} C、float f(int x, int y) {float z; z=x/y; return z;} D、fun(int x, y) { int z; return z; }

5. 已知有宏定义#define SQR(a) 2*a*a,则SQR(3+4)的值为(A). A、22 B、32 C、98 D、18

6. 以下正确的说法是(A).

A、函数的类型决定返回值的类型

B、定义函数时,形参的类型说明可以放在函数体内 C、return后面不能为表达式

D、如果形参与实参的类型不一致,以实参类型为准

7. C语言规定,函数返回值的类型是由(A)。 A、在定义该函数时所指定的函数类型所决定 B、return语句中的表达式类型所决定 C、调用该函数时系统临时决定

D、调用该函数时的主调函数类型所决定

8. 若调用一个函数,且此函数中没有return语句,则正确的说法是: 该函数(B)。 A、没有返回值

B、返回一个不确定的值 C、返回若干个系统默认值 D、能返回一个用户所希望的值

9.设函数的调用形式如下: f((x1, x2),(y1,y2,y3)),则函数有 (A)个形参. A、2 B、4 C、3 D、5

10.在\文件包含\的预处理中,被包含的文件应是(A). A、源文件 B、可执行文件 C、目标文件 D、批处理文件

11.以下程序的输出结果为(C)。 main()

{int a=1,b=2,c=3,d=4,e=5;

printf(\ }

int func(int x,int y) { return(x+y); } A、9 B、15 C、13

D、函数调用出错

12.以下正确的说法是(D)。

A、用户若需调用标准库函数,调用前不必使用预编译命令将该函数所在文件包括到用户源文件中,系统自动去调

B、用户若需调用标准库函数,调用前必须重新定义 C、系统根本不允许用户重新定义标准库函数

D、用户可以重新定义标准库函数,若如此,该函数将失去原有含义

13.在#include命令中,文件名可用双引号或尖括号括起来,对于二者的下列说法中正确的是(A).

A、用尖括号时,直接按系统标准方式检索文件目录. B、用双引号时,直接按系统标准方式检索文件目录.

C、用双括号和尖括号时,都不检查源文件所在的文件目录. D、以上说法都不对.

14. C语言程序中必须有的函数是(B)。 A、#include \B、main C、printf D、scanf

15. 程序运行结束后,屏幕上输出值为( B). static int x=10; main( ) { int x=3; f( ); x- -;

printf(\ } f( ) { x++; } A、10 B、2 C、11 D、3

16. file1.c中有命令,#include ,若file2.c中有全局静态变量a,则( B). A、a在file1.c中应用extern说明.

B、a在file1.c中有效,不必用extern说明. C、a在file1.c中不生效

D、a在file1.c和file2.c中均不生效.

17.以下叙述中正确的是(C)。

A、可以在一个函数中定义另一个函数

B、main()函数必须放在其它函数之前 C、构成C程序的基本单位是函数

D、所有被调用的函数一定要在调用之前进行定义

18.在执行\文件包含\命令时,下列说法正确的是(A). A、作为一个源程序编译,得到一个目标文件. B、一个 include 命令可指定多个被包含文件. C、在编译时作为两个文件联结.

D、被包含的文件可以是源文件或目标文件.

19.在定义全局变量和局部静态变量的同时赋值,变量的初始化在(C)时确定的. A、运行 B、编辑 C、编译 D、调试

20.关于建立函数的目的,以下正确的说法是(A)。 A、提高程序的可读性 B、减少程序文件所占内存 C、减少程序的篇幅 D、提高程序的执行效率

21.以下函数调用语句中实参的个数是(D)。 func((e1,e2),(e3,e4,e5)); A、3 B、5

C、语法错误 D、2

22.设有宏定义#define SUB(x,y) (x)*y,且a=3,b=4,则 SUB(a++,b++) 的值为(D). A、13 B、16 C、20 D、12

23.在宏定义#define PI 3.14159中, 用宏名替换一个(A). A、字符序列 B、函数名 C、单精度数 D、双精度数

24.以下标识符中可以作为用户函数名的是(D). A、struct B、int

C、union D、go_to

25.以下叙述错误的是(B).

A、函数调用可以出现在一个表达式中 B、函数调用可以作为一个函数的形参 C、函数调用可以作为一个函数的实参 D、函数允许递归调用

26.若用数组名作为函数的实参,传递给形参的是(B)。 A、数组第一个元素的值 B、数组的首地址 C、数组元素的个数 D、数组中全部元素的值

27.在C语言程序中(B)。

A、函数的定义可以嵌套,但函数的调用不可以嵌套 B、函数的定义不可以嵌套,但函数的调用可以嵌套 C、函数的定义和函数调用不可以嵌套 D、函数的定义和函数调用均可以嵌套

28.下列说法中正确的是(B).

A、函数调用不占运行时间,只占编译时间. B、宏替换不占运行时间,只占编译时间. C、有参数的宏定义,就是函数.

D、在定义宏时,宏名与带参数的括弧之间可以加空格.

29.函数定义时的参数为形参,调用函数时所用的参数为实参,则下列描述正确的是(C). A、实参与形参是双向传递 B、形参可以是表达式 C、形参和实参可以同名

D、实参类型一定要在调用时指定

30.以下错误的描述是:函数调用可以(D)。 A、出现在执行语句中 B、做为一个函数的实参 C、出现在一个表达式中 D、做为一个函数的形参

31.以下不正确的说法是:C语言规定(C)。 A、实参可以是常量,变量或表达式 B、实参可以为任何类型

C、形参可以是常量,变量或表达式 D、形参应与其对应的实参类型一致

32.下列形式,不属于编译预处理命令的是(D). A、#ifdef M B、#undef M C、#if (M>1) D、while (M>1)

33.执行下面程序后,输出结果是(D)。 main()

{ int a,b,c; a=45,b=27,c=0; c=max(a,b);

printf(\}

int max(int x,int y) { int z;

if(x>y) z=x; else z=y; return(z); } A、72 B、18 C、27 D、45

34.在C语言的函数中,下列正确的说法是(B)。 A、形参可以是常量和变量 B、可以有也可以没有形参 C、数组名不能作形参 D、必须有形参

二、判断题

1. 在C程序中, 函数既可以嵌套定义, 也可以嵌套调用。F

2. 在主函数中,必须要对被调用函数进行类型说明,否则在编译时会出现错误.F

3. 在程序中的第二个函数之后定义了某全局变量,则该程序的所有函数均可使用它.F 4. 函数调用语句:func(rec1,rec2+rec3,(rec4,rec5));中,含有的实参个数是5.F 5. 函数的返回值可以通过函数中的return语句获得。T

6. 通过return语句,函数可以带回一个或一个以上的返回值。F 7. C语言中,通过函数调用只能获得一个返回值.F ?1801 8. 变量根据其作用域的范围可以分作局部变量和全局变量.T

9. 当全局变量与局部变量同名时,在局部变量的作用域范围之内,局部变量起作用.T 10.对静态变量的初始化不是在编译阶段完成的.F

11.当变量的存储类型定义缺省时,系统默认为变量的存储类型为auto类型,分配在静态区.F

12.静态局部变量是在编译时被初始化的,故它只被赋初值一次.T 13.没有初始化的数值型静态局部变量的初值是不确定的值. F 14.对静态变量的初始化不是在编译阶段完成的.F 15.对静态数组的初始化是在编译阶段完成的. T

16.每次调用函数时,都要对静态局部变量重新进行初始化.F 17.函数调用结束后,静态局部变量所占用的空间被释放.F

18.在一个函数中定义的静态局部变量可以被另一个函数调用.F 19.在一个函数中定义的静态局部变量不能被另外一个函数所调用.T

20.当全局变量与局部变量同名时,在局部变量的作用域范围之内,全局变量起作用.F 21.计算机编译系统对宏定义在编译时进行语法检查.F

22.若有宏定义:#define S(a,b) t=a;a=b;b=t由于变量t没定义, 所以此宏定义是错误的。F

23.如果字符串与宏名相同,则不管其是否在双撇号内,都要进行宏替换.F 24.在定义宏时,在宏名与带参数的括弧之间不应加空格.T 25.一个include 命令只能指定1个被包含的文件。T

26.被包含文件是在编译时先单独生成目标文件,然后连接到可执行文件中去.F

27.被包含文件与其所在的文件(即用#include命令的源文件),在预编译后,成为同一个文件.T

28.如果被包含文件中有全局静态变量,它们在用#include命令的源文件中有效.T 29.#define 和printf 都不是C语句。T

30.数组名可以作为函数的实参和形参.T ?1556

31.数组名作为函数调用时的实参,实际上传递给形参的是数组第一个元素的值.F 32.数组名作为函数调用时的实参,实际上传递给形参的是数组全部元素的值.F

三、填空题

1. C语言中一个函数由函数首部和_____两部分组成. 函数体 2. 函数不可以进行嵌套定义,但可以进行嵌套_____. 调用

3. 如果函数不要求返回值,可用_____来定义函数为空类型. void

4. 从函数的形式上看,函数分为无参函数和_____两种类型. 有参函数【8】 5. 函数调用语句func((e1,e2),(e3,e4,e5))中含有_____个实参. 2 6. 函数的_____调用是一个函数直接或间接地调用它自身. 递归 7. 函数调用时的实参和形参之间的数据是单向的_____传递.值

8. 静态变量和外部变量的初始化是在_____阶段完成的,而自动变量的赋初值是 在_____时进行的. (编译),(运行/函数调用/调用) ?1752

第9章 指针

一、单选题

1. 下列关于指针定义的描述,错误的是(A)。 A、指针是一种变量,该变量用来存放某个变量的值 B、指针是一种变量,该变量用来存放某个变量的地址值 C、指针变量的类型与它所指向的变量类型一致 D、指针变量的命名规则与标识符相同

2. 以下程序的输出结果是(A). main()

{char str[ ]=\A、68

B、不确定的值 C、字符D的地址 D、0

3. 若有 char s1[]=\则下列语句中能够实现当字符串s1大于字符串s2时,输出s2的语句是(C)。 A、if(strcmp(s2,s1)>0)puts(s2); B、if(strcmp(s2,t)>0)puts(s2); C、if(strcmp(s1,t)>0)puts(s2); D、if(strcmp(s1,s1)>0)puts(s2);

4. 若有说明:int *p,m=5,n;以下正确的程序段是(D)。 A、scanf(\B、p=&n;scanf(\C、p=&n;scanf(\D、p=&n;scanf(\

5. char h,*s=&h;可将字符H通过指针存入变量h中的语句是(A)。 A、*s='H'; B、s='H' C、*s=H; D、s=H;

6. 函数fun用于将一字符串按相反次序显示,则横线上的表达式为(D). void fun(char *s) { if(! *s) return; _____;

printf(\

}

A、printf(\B、fun(*(s+1));

C、printf(\D、fun(s+1);

7. 若有说明:int *p1,*p2,m=5,n; 以下均是正确赋值语句的选项是(A)。 A、p1=&m;p2=p1; B、p1=&m;p2=&p1 C、p1=&m;*p2=*p1;

D、p1=&m;p2=&n;*p1=*p2;

8. 下列程序的运行结果是:(B). void fun(int *a, int *b) { int *k;

k=a;a=b;b=k; }

main( )

{ int a=3,b=6,*x=&a, *y=&b; fun(x, y);

printf(\}

A、6 3 B、3 6 C、0 0 D、编译出错

9. 字符串指针变量中存入的是(A)。 A、字符串的首地址 B、字符串变量 C、第一个字符 D、字符串

10. 以下程序的输出结果是 (D). main( )

{char str[ ]=\

A、68

B、字符D的地址 C、不确定的值 D、0

11.以下程序段给数组所有的元素输入数据,请选择正确答案填入(C)。 #include main()

{ int a[10],i=0;

while(i<10) scanf(\ . . . }

A、&a[i+1] B、a+i C、a+(i++) D、&a[++i]

12. 若有说明:int n=2,*p=&n,*q=p;,则以下非法的赋值语句是(C)。 A、*p=*q; B、n=*q; C、p=n; D、p=q;

13.下述函数的功能是(C). int fun(char *x) { char *y=x; while(*y++); return y-x-1; }

A、比较两个字符串的大小 B、求字符串存放位置 C、求字符串的长度

D、将字符串x连接到字符串y后面

14.在说明语句:int *f();中,标识符f代表的是(A)。 A、一个返回值为指针型的函数名 B、一个用于指向函数的指针变量 C、一个用于指向一维数组的行指针 D、一个用于指向整型数据的指针变量

15.下面程序的输出结果应该是(B ). char s[ ]=\ main() {char *p;

for ( p=s;p

} A、DCBA

B、ABCDBCDCDD C、ABCDABCABA D、ABCD

16.变量p为指针变量,若p=&a,下列写法不正确的是(A)。 A、*(p++)==a++ B、&*p==&a C、(*p)++==a++ D、*&a==a

17.以下程序段 char *alp[]={\ int j; puts(alp[1]);的输出结果是(D)。 A、D B、A C、B D、DEF

18.下面判断正确的是(D)。

A、char c[4]=\等价于 char c[4]=d[4]=\B、char str[10]={\等价于char str[10];str[]={\C、char *a=\等价于 char *a;*a=\D、char *s=\等价于 char *s;s=\

19.int a[10]={1,2,3,4,5,6,7,8};int *p;p=&a[5];p[-3]的值是(D)。 A、4 B、2

C、不一定 D、3

二、判断题

1. 如果需要向函数内传递多个值,用数组和用指针效果是一样的.T 2. 将函数func的入口地址赋给指针变量p的语句是_____.p=func;

3. 定义 int a[ ]={1,2,3,4},y,*p=&a[1];,则执行y=(*--p)++后,y的值是2. F 4. 有如下说明:int a[10]={1,2,3,4,5,6,7,8,9,10},*p=a; 则数值为9的表达式是 *(p+8).T

5. 假设有int a[10], *p;则p=&a[0]与p=a等价。T

6. 设有如下定义:int *p; *p=100;则 printf(\的输出结果是100.N 7. char *p=\的含义是定义字符型指针变量p,p的值是字符串\。F 8. 数组名与指针变量是相互等价的.F

9. 在C语言中,函数名代表函数的入口地址.T

10.若 p 为指针变量,a 为数组名,则 a-p是合法的表达式.T 11.指向某一变量的指针,就是该变量的内存地址.T

23.若定义 int array[5], *p; 则赋值语句 p=array;是正确的.T

三、填空题

1. 定义int *p,a[5];将数组a的首地址赋给指针变量p的语句是_____.p=a;p=&a[0];【9】 定义int *p,a[5];将数组a的首地址赋给指针变量p的语句是_____. p=a; p=&a[0]; 执行下列语句后,*(p+1)的值是_____. b char s[3]=\

2、将数组a的首地址赋给指针变量p的语句是_____. p=a; 或 p=&a[0]; 3、将函数funl 的入口地址赋给指针变量p的语句是_____. p=funl; 一

4、在c程序中,只能给指针变量赋NULL值和_____值. 地址

小写的L,不是数字

第10章 结构体与共用体

一、单选题

1. 对结构体类型的变量的成员的访问,无论数据类型如何都可使用的运算符是(B)。 A、& B、. C、* D、->

2. 定义结构体的关键字是(A)。 A、struct B、typedef C、enum D、union

3. C语言结构体类型变量在程序执行期间(B)。 A、没有成员驻留在内存中 B、所有成员一直驻留在内存中 C、只有一个成员驻留在内存中 D、部分成员驻留在内存中

4. C语言中,定义结构体的保留字是(C)。 A、typedef B、union C、struct D、enum

5. 当说明一个结构体变量时系统分配给它的内存是(D)。 A、成员中占内存量最大者所需的容量 B、结构中第一个成员所需内存量 C、结构中最后一个成员所需内存量 D、各成员所需内存量的总和

6. 在定义构造数据类型时,不能(A)。 A、末尾不写分号 B、说明存储类型 C、初始化 D、说明变量

7. 使用共用体变量,不可以(A)。 A、同时访问所有成员 B、进行动态管理 C、节省存储空间

本文来源:https://www.bwwdw.com/article/7gdt.html

Top