昆明理工大学C语言程序设计课后习题答案

更新时间:2024-04-24 07:26:01 阅读量: 综合文库 文档下载

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

昆明理工大学C语言程序设计课后习题答案

第1章认识C语言

(一)、是非题

1.程序是指挥计算机进行各种信息处理任务的一组指令序列。

A.对 B.错

2.机器语言与硬件平台相关,但汇编语言和硬件平台无关。

A.对 B.错

3.编译型高级语言明显优于解释型高级语言。

A.对 B.错

4.C语言把高级语言的基本结构和低级语言的实用性紧密结合起来,不仅适合编写应用软件,

而且适于编写系统软件。 A.对 B.错

5.面向对象的程序设计方法明显优于面向过程的程序设计方法。

A.对 B.错

6.计算机算法要有一个明确的起点和确定的步骤序列。

A.对 B.错

7.main函数是C程序的入口,由计算机系统负责调用。

A.对 B.错

8.在C语言中,同一行上可以写一条或多条语句,但一条语句不能写在多行上。

A.对 B.错

9.在C语言中,扩展名为.h的文件称为头文件,常用于组织C标准函数库中的函数。

A.对 B.错

10.注释语句会增加编译结果的复杂性,因此要尽量减少注释语句的数量。

A.对 B.错

11.声明变量的含义是通知编译系统为变量分配合适大小的存储空间。

A.对 B.错

12.C语言不允许使用关键字作为变量的名称,但可以使用保留字为变量命名。

A.对 B.错

13.符号常量提高了程序的可读性,但降低了程序维护的方便性。

A.对 B.错

14.变量声明把一个具体的标识符名称和计算机内存中的一个特殊的位置联系起来,同时确

定了该位置存储的信息类型。 A.对 B.错

15. C语言允许在同一条语句中定义多个相同类型的变量,其间用分号进行分隔。

A.对 B.错

16.在ISO/ANSI 1999规定中,允许将变量声明放在程序中的任何位置。

A.对 B.错

17.不同类型的数据在内存中所占存储单元的大小不同,内部存储方式不同,取值范围不同,

甚至能够参与的运算种类也不相同。 A.对 B.错

18.有符号和无符号整数的区别仅在于对数据最高位的解释不同。若最高位解释为数据位,

则为signed类型;若最高位解释为符号位,则为unsigned类型。 A.对 B.错

19.默认形式的实数常量的数据类型为float类型。

A.对 B.错

20.实型变量能表示的数字的有效位数是有限的。

A.对 B.错

21.sizeof()是C语言提供的标准库函数,用于测试数据类型在系统中所占的字节数。

A.对 B.错

22.使用转义字符可输出ASCII码表中的任一字符。

A.对 B.错

23.char类型数据内部采用整数存储方式,因此它和int型数据可以互为通用。

A.对 B.错

24.在C语言中,保存字符串“B”实质上是保存字符'B'和'\\0'两个符号。

A.对 B.错

25.在C语言中,允许对两个字符型数据进行加法运算。

A.对 B.错 (二)、选择题

1.C语言是一种______。

A.汇编语言 B.“解释型”语言 C.“编译型”语言 D. 面向对象语言 2.下列说法中,正确的是______。

A.机器语言与硬件相关,但汇编语言与硬件无关 B.不同的计算机类型,其能理解的机器语言相同

C.汇编语言采用助记符提高程序的可读性,但同样属于低级语言 D.汇编源程序属于低级语言程序,计算机可以直接识别并执行 3.下面有关高级语言的说法中,正确的是______。

A.高级语言编写的程序可读性好,执行效率也最高

B.高级语言程序必须翻译成机器语言程序,计算机才能执行

C.解释方式和编译方式相比,具有占用内存少、执行速度快的特点 D.C语言是一种解释型高级语言

4.下面有关C语言特点的说法中,错误的是______。

A.C语言编写的代码较为紧凑,执行速度也较快

B.C语言不仅适合编写各种应用软件,还适于编写各种系统软件 C.C语言是一种模块化和结构化的语言 D.C语言编写的程序通常不具备移植性

5.下面有关程序设计技术的说法中,错误的是______。

A.机器语言和汇编语言编程通常采用面向计算机的程序设计方式 B.面向过程的程序设计方法通常采用结构化和模块化设计方法 C.面向对象的程序设计方法采用客观世界的描述方式

D.C语言是一种兼顾面向过程和面向对象的高级程序设计语言 6.下面有关C程序操作过程的说法中,错误的是______。

A.C源程序经过编译,得到的目标文件即为可执行文件

B.C源程序的链接实质上是将目标代码文件和库函数等代码进行连接的过程 C.C源程序不能通过编译,通常是由于语法错误引起的

D.导致不能得到预期计算结果的主要原因是程序算法考虑不周 7.一个C语言程序是由________组成。

A.主程序B.子程序 C.函数 D.过程 8.C源程序中不能表示的数制是______。

A.二进制 B.八进制 C.十进制 D.十六进制 9.一个C语言程序总是从__________开始执行。

A.主程序 B.子程序 C.主函数 D.函数 10.以下叙述中正确的是_______。

A.在C程序中,main函数必须位于程序的最前面 B.C程序的每一行中只能写一条语句

C.在对一个C程序进行编译的过程中,可发现注释中的拼写错误 D.C语言本身没有输入输出语句 11.以下叙述中正确的是_________。

A.C程序的基本组成单位是语句 B.C程序中的每一行中只能写一条语句 C.C语句必须以分号结束 D.C语句必须在一行内写完 12.以下叙述中错误的是_________。

A.函数是C程序的基本组成单位 B.函数体一般由一组C语句序列组成

C.printf是C语言提供的输出语句 D.函数通常分为库函数和用户自定义函数两种

13.以下程序的输出结果是______。 #include \void main()

{int a=2,b=3,c=4;

printf(\

A.4 3 2 B.2,3,4 C.4,3,2 D.2 3 4 14. C语言中,最基本的数据类型是_________。

A.整型、实型、逻辑型 B.整型、实型、字符型

C.整型、字符型、逻辑型 D.整型、实型、逻辑型、字符型 15.下面有关变量声明的说法中,正确的是_________。

A.C语言中不用先声明变量,需要时直接使用即可

B.每个变量的存储空间大小由数据类型和编译环境共同决定

C.在VC++6.0环境下,为int型变量分配的存储空间大小为2个字节 D.变量声明时,不能进行赋值操作

16.若x和y为整型变量,对于scanf(\语句,可使x和y的值分别为10和20的正确输入方法是_________。

A.10 20 B.10, 20C.a=10 b=20 D.a=10,b=20 17.下列标识符中,不合法的用户标识符为_________。

A.aBa B._11 C.a_1 D.a&b

18.下列标识符中,合法的用户标识符为_________。

A.month B.5xy C.int D.your name 19._________是C语言提供的合法的数据类型关键字。

A.Boolean B.signed C.integer D.Char 20.不合法的字符常量是_________。

A.'\\678'B.'\\\C.' ' D.'\\4' 21.不正确的字符串常量是_________。

A.'abc' B.\C.\ D.\22.关于下面的程序,正确的说法是_________。

#includestdio.h void main()

{ float a=b=2, result; result=a/b;

printf(\

A. 程序可正常编译,结果为result=1.000000B. 共有1处语法错误

C. 共有2处语法错误 D. 共有3处语法错误 23.下面变量声明的语句中,错误的是_________。

A.char c=B; B.int a=3C. char c=65; D.float area=0; 24.关于下面的程序,正确的说法是_________。

#include void main() { int x,y,z; x=y=z=1;

printf(\A.程序无误,能正常通过编译

B.#include 有误,需改为#include \C.int x,y,z;有误,需改为int x; y;z; D.x=y=z=1;有误,需改为x=1; y=1;z=1;

25.已知字母A的ASCII码为十进制数65,且c2为字符型,则执行语句c2='A'+'6'-'2';

后,c2中的值为__________。 A.69 B.C C.D D.E

26.为了计算s=10!,则定义变量s时应该使用的数据类型是________。

A.int B.unsigned C.long D.以上三种类型均可 27.以下选项中合法的标识符是________。

A.1_1 B.1-1 C._11 D.1_

28.下列关于C语言用户标识符的叙述中正确的是________。

A.用户标识符中可以出现下画线和中划线(减号) B.用户标识符中不可以出现中划线,但可以出现下画线

C.用户标识符中可以出现下画线,但不可以放在用户标识符的开头

D.用户标识符中可以出现下画线和数字,它们都可以放在用户标识符的开头 29.以下选项中,能用作数据常量的是________。

A.0119 B.o126 C.2.5e2.5 D.119L

30.以下关于short、int和long类型数据占用内存大小的叙述中正确的是________。

A.均占4个字节 B.根据数据的大小决定所占内存的字节数 C.由用户自己定义 D.由C语言编译系统决定

31.若已定义char c='\\010',则变量c所占的字节数为__________。

A.1 B.2 C.3 D.4

32.要定义双精度实型变量a和b,并初始化为数值7,则正确的语句是__________。

A.double a,b;a=b=7; B.double a=b=7; C.double a=b=7; D.double a=7,b=7;

33.已知字符a的ASCII码值为97,则以下程序的输出结果是__________。

#include \void main() { char ch='c';

printf(\

A.c99 B.c98 C.c97 D.编译出错 34.以下程序运行后的输出结果是_________。

#include “stdio.h” void main() {char c; c='B'+32;

printf(\

A.B B.b C.B32 D.b32 35.以下程序运行后的输出结果是_________。

#include \void main() { char c1,c2; c1='a';c2='b'; c1=c1-32; c2=c2-32;

printf(\ printf(\

A.A B B.A B C.a b D.a b 65 66 97 98 65 66 97 98 36.如果将一个函数的返回值类型说明为void,则表示_________。

A.该函数可以返回任意类型的值 B.该函数不能返回任何值

C.该函数可以返回基本类型的值

D.该函数是main函数,是程序运行的起点 37.对于int型常量,不正确的是__________。

A.029 B.-25 C.0x2A D.-0X28 38.下列整型常量,错误的是__________。

A.025 B.285LC.-285u D.285lu

39.以下有关整型变量的定义中,错误的是___________。

A.short int x; B.long x; C.unsigned x; D.short x; 40.下列实型常量,错误的是__________。

A.3.2f B.-2.2E-2F C.-12.0 D.e3

41.在VC++6.0环境下,sizeof(int)和sizeof(float)的值分别为__________。

A.2,2 B.2,4 C.4,4 D.4,8

42.对于浮点型数据,下列说法中不正确的是______。

main()

{ int a,b,d=25; a=d/10%9; b=a+-1; printf(\A.6,1B.2,1 C.6,0 D.2,0 36.以下叙述中正确的是______。

A.调用printf函数时,必须要有输出项

B.使用putchar函数时,必须在之前包含头文件stdio.h

C.在C语言中,整数可以以十二进制、八进制或十六进制的形式输出

D.调用getchar函数读入字符时,可以从键盘上输入字符所对应的ASCII码 37.程序如下,下叙述中正确的是______。 #include main()

{ char a1='M',a2='m';printf(\A.程序输出大写字母M B.程序输出小写字母m

C.格式说明符不足,编译出错 D.程序运行时产生出错信息 38.以下程序运行时若输入:a<回车>,则叙述正确的是______。 #include main()

{ char c1='1',c2='2'; c1=getchar(); c2=getchar();putchar(c1); putchar(c2);} A.变量c1被赋予字符a,c2被赋予回车符 B.程序将等待用户输入第2个字符

C.变量c1被赋予字符a,c2中仍是原有字符2 D.变量c1被赋予字符a,c2中将无确定值 39.设有定义:int a; float b;,执行scanf(\语句时,若从键盘输入:876

543.0,a和b的值分别是________。 A.876和543.0 B.87和6.0C.87和543.0D.76和543.0

40.若在定义语句:int a,b,c;之后,接着执行以下选项中的语句,则能正确执行的语句是

________。

A.scanf(\B.scanf(\

C.scanf(\D.scanf(\

41.已知字符'A'的ASCII码值是65,字符变量c1的值是'A',c2的值是'D'。执行语句

printf(\后,输出结果是________。 A.A,B B.A,68C.65,66 D.65,68

42.程序段:int x=12; double y=3.141593;printf(\的输出结果是________。 A.12 3.141593 B.123.141593 C.12,3.141593 D.123.1415930 43.若要求从键盘读入含有空格字符的字符串,应使用函数________。 A.getc() B.gets() C.getchar() D.scanf()

44.有以下程序,其中%u表示按无符号整数输出,程序运行后的输出结果是______。 #include main()

{ unsignedintx=0xFFFF; printf(\A.-1 B.65535 C.32767 D.0XFFFF (三)、编程题

1.编写一个程序,从键盘输入圆的半径,计算并输出该圆的周长、面积和体积。 2.输入四个季度的销售额(整型),计算并输出各季度自年初起的累计销售额,计算并

输出第一季度外的三个季度的环比增长率(环比增长率是本期与相比上一期的增长率,针对本题目,即为本季度对上季度的增长率)。

3.从键盘输入四门课程的(整数)分数,输出成绩信息,计算并输出平均分数。要求输入输出有一定提示,输出的平均分数保留二位小数。

第3章选择结构

二、习题

(一)、是非题

1.关系运算符是双目运算符,其功能是将两个运算对象进行大小比较。

A.对 B.错

2.对于与运算“&&”,只有当两个运算对象都为真时运算结果才为真。

A.对 B.错

3.使用条件表达式可以构成各种各样的两路选择结构。

A.对 B.错

4.条件可以是任何类型的表达式,如逻辑型,关系型,数值型等,单个已赋过值的变量或常

量也可以作为表达式的特例。 A.对 B.错

5.else子句不能单独作为语句使用,它是if语句的一部分,必须与if配对使用。

A.对 B.错

6.C语言规定,else总是与它上面最远的if配对。

A.对 B.错 7.在switch语句中,每一个case后的常量表达式的值不能相同,因为选择结构中只允许一

个分支所对应的语句组被执行。 A.对 B.错 8.在执行switch选择结构时,从匹配表达式的相应case处入口,一直执行到break语句或

到达switch的末尾为止 A.对 B.错

9.在C语言中,运算符“=”与“==”的含义都是等于。

A.对 B.错

10.当进行比较的运算对象是字符型数据时,则按字符的ASCII码值从左到右逐个对应比较,

先大为大。

A.对 B.错

11.判断字符变量ch的值是否为数字字符的表达式为(ch>='0') && (ch<='9')。

A.对 B.错

12.条件运算符“?:”是C语言中唯一的一个三目运算符,该运算符可以嵌套使用。

A.对 B.错

13.在C语言中用0表示逻辑值“真”,用非0表示逻辑值“假”。

A.对 B.错

14.在C语言中,所有的逻辑运算符的优先级都一样。

A.对 B.错

15.在C语言中,逻辑运算符的优先级高于算术运算符和关系运算符。

A.对 B.错

16.数学表达式“|x|>4”对应的C语言表达式是“x<-4||x>4”。

A.对 B.错

17.与表达式“!(x>0)”等价的表达式是“x<=0”。

A.对 B.错

18.与表达式“!0”等价的表达式是“1”。

A.对 B.错

19.当a=1,b=2,c=3时,执行语句“if(a>c) b=a;a=c;c=b;”后,变量c中的值为3。

A.对 B.错 a=1,b=2,c=3; if(a>c) b=a; a=c; c=b; b=2

20.当a=1,b=2,c=3时,执行语句“if(a>c) {b=a;a=c;c=b;}”后,变量c中的值为2。

A.对 B.错 a=1,b=2,c=3; if(a>c)

{b=a;a=c;c=b;} C=3 二)、选择题

1.判断char型变量ch是否为小写字母的正确表达式是______。

A.'a'<=ch<='z' B.(ch>='a') & (ch<='z') C.(ch>='a') && (ch<='z') D.('a'<=ch) AND ('z'>=ch) 2.为表示关系100≥b≥0,应使用C语言表达式______。

A.(100>=b)&&(b>=0) B.(100>=b)and(b>=0) C.100>=b>=0 D.(100>=B)&&(B>=0)

3.以下运算符中优先级最高的运算符为______。

A.! B.&& C.!= D.%

4.设x、y和z是int型变量,且x=3,y=4,z=5,则下面表达式中值为0的是______。

A.'x'&&'y' B.x<=y C.x||y+z&&y-z D.!((x

5.执行以下程序段后,x的值为______。

int a=14,b=15,x; char c='A';

x=(a&&b)&&(c<'B');

A.true B.1 C.false D.0 6.下列表达式中,______不是关系表达式。

A.x%2==0 B.!(x%2)

C.(x/2*2-x)==0 D.x%2!=0 7.执行以下程序后,输出的结果是______。

include \main()

{int a=2,b=-1,c=2;

if(a

A.0 B.1 C.2 D.3

8.执行以下程序后,输出的结果是______。

include \main()

{int w=4,x=3,y=2,z=1;

printf(\

A.4 B.2 C.1 D.3

9.执行以下程序段后,输出结果是______。

int a=3,b=5,c=7; if(a>b) a=b;c=a; if(c!=a) c=b;

printf(\

A.程序段有语法错误 B.3,5,3

C.3,5,5 D.3,5,7 10.下面程序段的输出结果是______。

int a=-1,b=4,k;

k=(a++<=0)&&(!b--<=0); printf(\

A.0,0,3 B.0,1,2 C.1,0,3 D.1,1,2

11.若有定义:float x=1.5;int a=1,b=3,c=2; ,则正确的switch语句是______。

A.switch(x) B.switch(int(x))

{case 1.0: printf(\

case 2.0: printf(\} }

C.switch(a+b) D.switch(a+b)

{case 1: printf(\

case 2+1: printf(\} }

12.下面程序段的输出结果是______。

int n='c';

switch(n++)// n先用,后自增(n=’c’)。 {default: printf(\case'a': case 'A': case 'b':

case 'B': printf(\

case 'c':

case 'C': printf(\case 'd':

case 'D': printf(\

A.passwarn B.passerror C.goodpasswarn D.pass 13.下述程序段的输出结果是_______。

int a=2,b=3,c=4,d=5; int m=2,n=2;

a=(m=a>b)&&(n=c>d)+5; printf(\

A.2,5 B.0,5 C.2,6 D.0,6 14.若a是数值类型,则逻辑表达式(a==1)||(a!=1)的值是_______。

A.0 B.1 C.2 D.不能确定 15.已知int x=10,y=20,z=30;,以下语句执行后x,y,z的值是_______。

if(x>y)

z=x; x=y; y=z;

printf(\

A.10,20,30 B.20,30,20 C.20,30,10 D.20,30,30

16.当a=1,b=3,c=5,d=4,x=0时,执行完下面一段程序后x的值是_______。

if(a>b) if(cc) if(b

A.7 B.2 C.3 D.6 17.设变量a、b、c、d和y都已经正确定义并赋值,则以下if语句的所表示的含义是_______。

if(a

A.a

B.a

#inlude main()

{ int x=1,y=0,a=0,b=0; switch(x)

{ case 1: switch(y) { case 0: a++; break;

void main() {int i,j,x=0;

for(i=0;i<2;i++) {x++;

for(j=0;j<=3;j++){if(j%2)continue;x++;} x++; }

printf(\

A.x=4 B.x=8 C.x=6 D.x=12

32.设变量已正确定义,则以下能正确计算f=n!的程序段是_______。 A.f=0; B.f=1; for(i=1;i<=n;i++) for(i=1;i<=n;i--) f*=i;f*=i;

C.f=1; D.f=1;

for(i=n;i>1;i++) for(i=n;i>=2;i--) f*=i; f*=i;

33.以下程序运行后的输出结果是_______。

#include \void main() { int k=5,n=0; while(k>0) { switch(k)

{ default : break; case 1 : n+=k; case 2 :

case 3 : n+=k;} k--;}

printf(\

A.0 B.4 C.6 D.7 34.以下程序的输出结果是_______。

#include \void main() {int a=1,b;

for(b=1;b<=10;b++) {if(a>=8)break;

if(a%2==1){a+=5;continue;} a-=3; }

printf(\A.3 B.4 C.5 D. 6

35.以下程序输出结果是_______。 #include \void main() {int i;

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

switch(i)

{ case 0:printf(\ case 2:printf(\default:printf(\

A.022111 B.021021 C.000122 D.012 36.以下程序输出结果是_______。 #include \void main() { int i=0,s=0; for(;;)

{if(i==3||i==5) continue; if(i==6) break; i++;s+=i;};

printf(\

A.10 B.13 C.21 D.程序进入死循环 37.若变量已正确定义,要求程序段完成求5!的计算,不能完成此操作的程序段是_______。 A.for(i=1,p=1;i<=5;i++) p*=i; B.for(i=1;i<=5;i++){ p=1;p*=i;} C.i=1;p=1;while(i<=5){p*=i; i++;} D.i=1;p=1;do{p*=i;i++;}while(i<=5); 38.以下程序执行后的输出结果是_______。

#include \void main()

{ int x=0,y=5,z=3;

while(z-->0&&++x<5) y=y-1; printf(\

A.3,2,0 B.3,2,-1 C.4,3,-1 D.5,-2,-5 39.以下程序执行后的输出结果是_______。

#include \void main() { int i,n=0; for(i=2;i<5;i++)

{ do{ if(i%3) continue;n++; }while(!i); n++; }

printf(\

A.n=5 B.n=2 C.n=3 D.n=4

40.下面程序的功能是输出以下形式的金字塔图。在下划线处应填入的是_______。

*

*** ***** ******* #include \voidmain( ) { int i,j;

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

{ for(j=1;j<=4-i;j++) printf(\for(j=1;j<=_______;j++) printf(\printf(\}

A.i B.2*i-1 C.2*i+1 D.i+2

第5章 数组

二、习题

(一)、是非题

1.数组名代表数组的首地址。

A.对 B.错

2.字符型数组可以用来存储字符串,因此可以用字符串初始化数组,例如:char str[]=\

Programming\。

A.对 B.错

3.函数strcpy(str1,str2)是将字符串 str2 连接到字符串 str1之后。

A.对 B.错

4.一个数组可以存储不同类型的数据。

A.对 B.错

5.数组在定义时可以不指定数组的长度,可根据程序中实际使用的元素个数决定。

A.对 B.错

6.在 C 语言中,只有当两个字符串所包含的字符个数相同时,才能比较大小。例如,字符串“That”与“The”就不能进行大小比较。 A.对 B.错

7.若有定义:int a[10];,使用数组元素时,下标的最小值是1,最大值是10。

A.对 B.错

8.在 C 语言中引用数组元素时,其数组的下标可以是任何类型的表达式。

A.对 B.错

9.任何一维数组的名称都是该数组存储单元的开始地址,且其每个元素按照顺序连续占用存储空间。

A.对 B.错

10.一维数组的元素实质上就是一个变量,代表内存中的一个存储单元。

A.对 B.错

11.若有说明:int a[3][4]={0};,则只有元素a[0][0]可得到初值0。

A.对 B.错

12.若有说明:int a[][3]={1,2,3,4,5,6,7};,则a数组第一维的大小不能确定。

A.对 B.错

13.若一维数组在定义时进行了初始化,则可以省略数组长度,系统会根据初始值个数确定该数组长度。

A.对 B.错

14.数组初始化时,若初始值的个数少于数组定义的长度,C语言会自动将剩余的元素初始化为初始化列表中最后一个初始值。

A.对 B.错

15.可以对字符型数组进行整体输入、输出。

A.对 B.错

16.可以对实型数组进行整体输入、输出。

A.对 B.错

17.设有定义:double a[4][5];,则数组a中元素的个数是9。

A.对 B.错 18.设有定义:int a[3][4]={{1,2,5,3},{2,4,7,9},{3,6,5,8}};,则表达式a[1][2]+a[2][3]的值9。

A.对 B.错 19.设有定义:char s[]={\,则执行printf(\后输出的值是6。

A.对 B.错

20.设有两个整型数组a和b,可以通过a=b,将数组b整体赋值给数组a。

A.对 B.错 (二)、选择题

1.设有两字符串“Good”、“Morning”分别存放在字符数组 str1[10]、str2[10]中,下面语句中能把“Morning”连接到“Good”之后的是______。 A.strcpy(str1,str2); B.strcpy(str1, \

C.strcat(str1, \ D.strcat(\2.以下对一维整型数组 a 定义正确的是______。

A.int a(10); B.int n=10,a[n];

C.int n;scanf(\D.#define SIZE 10 int a[SIZE];

3.下列字符串赋值语句中,不能正确把字符串“Hello World”赋给数组的语句是______。

A.char a1[]={'H','e ','l','l','o','','W','o','r','l','d','\\0'}; B.char a2[15]; strcpy(a2,\C.char a3[15]; a3=\D.char a4[10]={ \

4.用 scanf 函数输入一个字符串到数组 str 中,下面正确的语句是______。

A.scanf(\ B.scanf(\C.scanf(\ D.scanf(\

5.以下能对二维数组 a 进行正确说明和初始化的语句是______。

A.int a()(3)={ (1,2,3),(2,4,6)};B.int a[2][]={{3,2,1},{5,6,7}}; C.int a[][3]={{3,2,1},{5,6,7}};D.int a(2)()={(1,2,3),(2,4,6)}; 6.判断字符串 a 和 b 是否相等,应当使用______。

A.if(a==b) B.if(a=b)

C.if(strcat(a,b)) D.if(strcmp(a,b))

7.有字符数组 a[80]和 b[80],则正确的输出语句是______。

A.puts(a,b); B.puts(a);puts(b);

C.printf(\ D.putchar(a,b); 8.下面程序的运行结果是______。 #include main()

{int a[5],i;

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

{ a[i]=9*(i-2+4*(i>3))%5; printf(\

A.-3-404 4 B.-3-4043C.-3-40 4 2 D.-3-40 4 0

9.假设 array 是一个有 10 个元素的整型数组, 则下列写法中正确的是______。

A.array[0]=10; B.array=0;C.array[10]=0;D.array[-1]=0; 10.下面程序的运行结果是______。

#include main()

{int a[3],i,j,k;

for(i=0;i<3;i++) a[i]=0; k=2;

for(i=0;i

printf(\

A.0 B.1 C.2 D.3 11.若有定义:int a[5]={1,2,3,4,5};char b='c',c;,则下面表达式中数值为 2 的是______。

A.a[2] B.a[c-b] C.a[b] D.a[b-'b'] 12.下面程序的运行结果是______。

#include main()

{int a[3][3]={1,2,3,4,5,6,7,8,9},i;

for(i=0;i<=2;i++)printf(\A.3 5 7 B.3 6 9C.1 5 9 D.1 4 7 13.下面程序的运行结果是______。

#include main()

{char c[5]={'a','b','\\0','c','\\0'}; printf(\

A.'a' 'b' B.abC.ab c D.ab\\0c\\0 14.下面程序的运行结果是______。

#include main()

{char s[12]= \printf(\

A.6 B.7 C.10 D.12

15.若有说明:int a[3][4]; 则对a数组元素的正确引用是______。

A.a[2][4] B.a[1,3]C.a[1+1][0] D.a(2)(1)

16.以下各组选项中,均能正确定义二维实型数组a的选项是______。

A.float a[3][4]; float a[][4]; float a[3][]={{1},{0}}; B.float a(3,4); float a[3][4]; float a[][]={{0};{0}}; C.float a[3][4]; static float a[][4]={{0},{0}}; D.float a[3][4]; float a[3][];

17.若二维数组a有m列,则计算任一元素a[i][j]在数组中位置的公式是______。(假设

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

Top