1、 C 语言经典习题及其答案详解 1 第一章 C 语言概述 1.1 单项选择题 1.二进制语言是属于( ) 面向机器语言 面向问题语言 面向过 程语言 面向汇编语言 解人们研制了许许多多计算机程序设计语 言,其中二进制语言直接来自计算机的指令系统, 与具体计算机紧密相关,所以是一种面向机器语 言。面向问题语言是为了易于描述和求解某类特定 领域的问题而专门设计的一种非过程语言。面向过 程语言是一种能方便描述算法过程的计算机程序 设计语言。有汇编语言,但没有面向汇编语言。汇 编语言也是一种面向机器的语言,与 机器语言比 较,汇编语言用有助于记忆的符号来代表二进制代 码。所以解答是。 2.下列语言中不
2、属于面向过程的语言是( ) 高级语言 低级语言 C 语言 PASCAL 语言 解 C 语言和 PASCAL 等程序设计语言都 是高级语言,它们用于描述复杂加工的处理过程, 所以也称它们是面向过程语言。低级语言是指机器 语言和汇编语言,低级语言是面向机器的语言,而 不是面向问题的语言。所以解答是。 3.下列字符中属于键盘符号的是( ) n t b 解键盘符号是指键盘上有标记,并能在显 示器上直接以其标记字样显示的字符。有许多键盘 上有标记的符号,它们不是用于直接显示的,键入 这种字符用于表示特定的意义,如常用的回车符。 为了能让 C 程序标记这种符号,程序采用转义字符 的方式书写这种字符。如 n
3、、 t 、 b都不是键盘 字符,在 C 语言中,它们都得用转义字符来表达。 只有字符 才是键盘字符。所以解答是。但在 C 程序中,反斜杠字符 已特别用作转义字符的引导 符,它也得用转义字符的表达形式书写,将它写成 。 4.下列字符列中,不是用来表达转义字符是 )( 074 0 解转义字符有三种书写形式:反斜杠字符 后接上某个规定的字符;反斜杠字符后接上 13 个 八进制数字符;反斜社字符和字符 X 之后接上 1 至 2 个十六进制数字符。后两种分别八进制数和十六 进制数直接给出字符的 ASCll 代码值。而 074 是八 进制整数,不是转义字。所以解答是。 5.不是 C 语言提供的合法关键字是
4、() switch begin case default 解 因 C 语言的关键字表中没有 begin,它 不是 C 语言的关键字。所以解答是。 6.下列字符列中,能作为单个标识符是() ? a a 2 a.3 a_3 解在 C 语言中,规定标识符是这样一种字 符序列,由英文字母或下线字符开始,后接任 1 个 英文字母、下线字符和数字符组成。所以问题所列 的字符列只有 a_3 是标识符,其余都不是标识符, 一个是由字符 ? 开头、一个中间有字符 ,另一 个有字符 . 。所以解答是。 1.2 填充题 7.在 C 语言中,下列说 法中错误的是() 函数定义可以分为两个部分:函数说明部分 和函数体
5、主函数可以调用任何非主函数 任何非主函数可以调用其它任何非主函数 程序可以从任何函数开始执行 解每个 C 函数的定义分两部分,函数说明 部分和函数体,所以叙述 是正确的叙述。 语言 C 中,函数可以递归调用,主函数可以调用程序中的 任何函数,当然可以调用任何非主教的其它函数, 所以叙述是一个正确的叙述。同样理由,叙述 也是正确的。 C 语言规, C 程序只有一个主函数, 并总是从主函数开始执行,不能从非主函数 开始执 行。所以,说程可以从任何函数开始执行是错误的。 所以解答是。 1.汇编语言属于面向 _语言,高级语言 属于面向 _语言。 解汇编语言与具体计算机密切有关,是属 于面向机器的语言;
6、而高级语言用来描述求解题的 算法,所以是面向过程的语言。所以解答是:面向 机器和面向过程。 2.用高级语言编写的程序称为 _程序, 它可以通过 _程序翻译一句执一句的方式 执 行 , 也 可 以 通 过 _ 程 序 一 次 翻 译 产 生 _程序,然后执行。 解用高级语言编写的程序称为源程序,源 程序不能在计算机上直接运行,运行源程序有种方 式:一种是通过解释程序,对源程序逐句解释执行; 另一种是先让编译程序将源程序一翻译产生目标 程序(目标程序是计算机可直接执行的机器语言程 序,它是一种二进制代码程),然后执行目标程序。 3.转义字符是由 _符号开始,后接单个 字符或若干字符组成。 4.C
7、语言词类主要分为 _、 _、 _和 _等。 解语言的基本词汇是指直接由字符序列 组 成,有确定意义的最基本单位,所以 C 语言词汇有: 字面形式常量、特殊符号(主要是运算符)、保留 字和标识符等四类。而表达式、函数调用等是更高 级的语言成分,如表达式中还可分运算分量和运算 符等;函数调用也是一种表达式,它有函数名标识 符、圆括号和实际参数表等。利用基本词汇,按照 给定的 C 语言的句法规则,就可命名程序对象,描 述表达式计算、构造语句、函数,直至整个程序。 5.C 语言的语句主要分为 _语句、 _语句、 _语句 _语句、 _语句和 _语句等。 解 C 语言有多种不同功能的语句,有用于 定义数据
8、的,有用于各种存储和计算的,有用于程 序流程控制的,有多种分类方法。 C 语言的语句主 要有:数据定义语句、表达式语句、流程控制语句、 复合语句、空语句和其它语句。程序中经常使用的 赋值表达式语句和函数调用表达式语句都是典型 的表达式语句。 6.C 程序是由函数构成的。其中有并且只能有 _个主函数。 C 语言程序 的执行总是由 _函 数开始,并且在 _函数中结束(如别的函数未 调用终止程序执行的库函数) 解 C 程序是由若干函数构成的。其中有并 且只能有 1 个主函数(用 main 命名) 程序的执。 C 行总是由主函数开始执行,通常在主函数中结束 (如没有在别的函数中调用终止程序执行的库函
9、数的话)。 第二章 基本数据类型和表达式 2.1 单项选择题 1.下列字符列中,可以作为 字符串常量 的是 () ABC ABC abc a 解 C 程序中,一个字 符率常量是表示一个 字符序列,书写时,用双引号字符前后括住这个字 符序列。所以只有 ABC 是一个正确的字符率常 量,其余都不是。其中, ABC 可作为标识符,字符 列 abc 不能出现在 C 程序中, a 是一个字符常量。 所以解答是。 2.在以字节存储字符的系统中, n 在内存占 用的字节数是( ) 1 2 3 4 解一般来说,一个字符在内存中只占 1 个 字节, n 是转义字符,其意义是换行符,它作为 一个字符存储,在内存也
10、只占 1 个字节。所以解答 是。 3.字符串 xyz 在内存占用的字节数是( ) 3 4 6 8 解字符串中的每个字符占 1 个字节,但 C 程序在存储字符串时,要在最后一个有效字符后面 接上 1 个字符串结束的标记符 0 。这样,存储字 符串常量 xyz 需要 4 个字节。所以解答是。 4.在以下字符列中,合法的长整型常数是( ) 0L 4962710 0.054838743 2.1869el0 解为表示不同范围的整数,整型数据分短 整型、基本型和长 整型,并对三种整型内部表示的 最高位的不同理解,又分别分成无符号和带符号两 种。若要明确指明一个整数是长整型的,必须在整 数之后接上字符 L
11、。所以 0L 是一个长整型的整型 常量,而 4962710 是基本整型数据,而对于用 2 个 字节表示一个基本整型数据的系统来说,该整数将 因超出范围而是一个错误的整数; 0.054839743 和 2.1869el0 都是 double 型的实数。所以解答是。 5.一个 char 型数据,它的值在内存中存放的是 () ASCll 代码值 BCD 代码值 内码值 十进制代码值 解计算机存储字符,通常是存储字符的某 种代码值。有许多种字符编码的方法,最流行的是 ASCII 代码。在 C 语言中, Char 型数据也用 ASCII 代码表示。所以解答是。 6.设变量 m, n, a, b, c,
12、d 的初值均为 0,执 行( m a b) |( n c d)后, m, n 的值是 () 0, 0 0, 1 l, 0 1, 1 解计算( m a b) |( n=c=d)的过程 是先计算逻辑或的左运算分量( m=a=b)的值, 由 于赋位运算符的优先级比关系运算符 =的优先级 低,又先计算 a=b.因 a, b 均为 0 后,所以比较 结果值为 1.将 1 赋给变量 m,使变量 m 的值变为 1 . 同时这个赋值运算的结果也是 1,这样逻辑运算的 左运算分量的值为 1.由于逻辑或运算的左运算分量 值为 1,按照 C 语言对逻辑或运算优化计算的规定, 不再计算逻辑或的右运算分量,而直接得到逻
13、辑或 运算的结果为 1 .由于逻辑或的右运算分量不曾计 算过,所以变量 n 的值也不为变化。这样,上述表 达式计算后,变量 m 的情为 1,变量 n 的值为 0.所 以解答是。 7.设 a 为 5,执行下列计算后, b 的值不为 2 的 是( ) b a 2 b 6-( -a) b a 2 b a 3? 3: 2 解因两个整型数据相除,结果是整数,当 a 的值为 5 时,计算表达式 b=a 2 后,使 b 的值为 2.计算表达式 b 6-( -a)是先计算子表达式( -a) 的,先让 a 的值减 1 变成 4,并以减 1 后的 a 为子 表达式的结果,所以子表达式的结果为 4,最后使 b 的值
14、为 2.在计算表达式 b= a%2 时,求余运算 a 2 的结果为 1,最后使变量 b 的值为 1.计算表达式 b a 3? 3: 2 时,先计算条件表达式 a 3? 3: 2, 以 2 为结果,最后也使变量 b 的值为人所以解答是 。 8.执行语句 x ( a 3, b a-); 后, X, a, b 的值依次为( ) 3, 3, 2 2, 3, 2 3, 2, 3 2, 3, 3 解计算表达式 x( a=3, b=a-)时,先计 算赋值号右端圆括号内的逗号表达式。逗号表达式 要求各子表达式顺序计 算,并以最后予表达式的值 为整个逗号表达式的结果。所以该表达式计算时, 先让变量 a 的值为
15、3, a-的值是 a 当时的值,以该 值为结果赋给变量 b,并以该值为逗号表达式的值 赋给变量 x,然后 a 的值被减少 1.所以计算该表达 式后,使变量 x, a, b 的值依次为 3, 2, 3.所以解 答是。 9.设整型变量 m, a, c, 均为 1, n, b, d执行 m( ab)( n a b) 后 m, n 的值是( ) 0, 0 0, l 1, 0 1 , l 解表达式( m a b)( n a b) 是一个逻辑表达式,它的计算过程是先计算逻辑与 的左分量( m a b,其中又是先计算 a b.因 a b 不成立,结果为 0,将 0 赋给变量 m,最后逻辑与 的左分量结果为
16、0.由于逻辑运算采用特别的优化计 算规则,当逻辑与的左分量结果为 0 时,不再计算 逻辑与的右分量,而直接以 0 为逻辑与的结果。所 以,上述表达式计算使 m 的值变为 0,而 n 的值没 有变,依旧为 l.所以解答是。 10,设有代码 int a 3; ,则执行了语句 a+=a -= a*a; 后,变量 a 的值是( ) 3 0 9 -12 解由于赋值运算符的结合性自右至左,语 句 a+=a -=a*a; 的执行是先计算 a*a,得到值 9, 再计算 a- a*a,使 a 的值为 -6,接着计算 a+ a, 使 a 的值为 -12.所以解答是。 11.在以下一组运算符中,优先级最高的运算符
17、是( ) % 解常规运算符的优先级自高到低的排列顺 序是算术运算符、移位运算符、关系运算符。按位 运算符、逻辑运算符、条件运算 符、赋值运算符、 逗号运算符。所以问题所给的四个运算符按优先级 自高到低的排列顺序是,。所以 解答是。 2 12.设整型变量 i 的值为 3,则计算表达式 i-i 后表达式的值为( ) 0 l 2 表达式出错 解有些运算符只有一个字符,也有许多运 算符由两个字符组成。特别是有些字符既可是单个 字符的运算符,又能组成双字符的运算符。编译系 统在识别源程序时,通常是尽量多地读八字符,能 组成多字符单词的先尽量组成多字符单词。所以表 达式 i-i,被编译器理解为( i-)
18、-i.另外,当表达 式中某变量有后缀自增和自减运算时,先按变量的 原值计算表达式,然后再对变量进行自增和自减运 算。同样地,当表达式中某变量有前缀自增和自减 运算时,先对变量进行自增和自减运算,然后再按 变量的新值计算表达式。按这个约定,求表达式 ( i-) -i 是计算 i-i 的值为 0,然后再对 i 作自减运 算。这样,表达式( i-) -i 的值为 0.所以解答是。 13. 设 整 型 变 量 a 、 b 、 c 均 为 2 , 表 达 式 a+b+c+ 的 结果是( ) 6 9 8 表达式出错 解与上一小题解答的理由相同,表达式 a+b+c+被系统理解成: ( a+) +( b+)(
19、) +c+)。表达式 变量 + 的值是变量的原来值,所 以在变量 a、 均为 2 的前题下, b.c执行上述表达式, 得到结果为 6.所以解答是。 14.若已定义 x 和 y 为 double 类型,则表达式: x l, y x 3 2 结果是( ) l 2 2.0 2.5 解由于变量 x 和 y 都是 double 类型,表达 式 x l, y x 3 2 是先计算 x 1,由于 1 是 整型的, x 是 double 类型的,该计算先将整数 1 转 换成 double 类型的 1.0,并将 1.0 赋给变量 x.计算 y x 3 2 是先求 3 2 的值,因是两整数相除, 结果是整型值 1
20、,然后在计算 x 1 时,也先将 1 转换成 1.0,然后求得 x l 的值为 2.0,最后将该 值赋给变量 y,并得到整个表达式的值为 2.0.所以 解答是。 15.设 a=1, b=2, c 3, d 4 则表达式 a b? a: c d? a: d 的结果为() 4 3 2 1 解条件运算符的优先级比关系运算符的优 先级低,并且它的结合性是自右向左的,所以表达 式 a b? a: c d? a: d 可用圆括号等价地写成( a b? a:( c main() float f, c; /*变量定义 */ printf( 输入 F 氏温度 ); scanf( f, f); c 5.0*( f
21、 32.0) 9.0; printf( 对应的 C 氏温度 6.2f n , c); 2.编一个程序,输入一个整数,输出其符号(若 0 ,输出 1;若 0 输出 -1)。 解程序可用 if 语句判断输入数的符号,并 控制输出 1 或 -l.程序如下: include main() int c; *变量定义 * printf( 输入一个整数 ); scanf( d , c); if( c 0) printf( 1 n ); else printf( -ln ); 3.编一个程序,输入 X 的值,按下列公式计算 并输出 y 的值。 x( xl ) y 2x l( l x 10) 3x-11( 10
22、x ) 解输入 x,按公式计算 y.这可用一个嵌套 的 if 语句分段判断并计算出 y 的值。然后输出 y 值。 程序如下: include stdio.h main() int x, y; *变量定义 * printf( 输入一个整数 ); scanf( d , x); if( x l) y x; else if( x 10) y 2*x l; else y 3*x 11; printf( y %d n , y); 4.编一个程序,输入三个单精度数,输出其中最 小数。 解设最小数存于变量 min 中,为求三个数 中的最小数,可分以下多步完成,先预置 min 为 x, 然后分别将其余两个数逐一
23、与 min 比较,当它们中 的某个值比存于 min 中的值更小时,就用它们更新 min.写出程序如下: include main() float x, y, z, min; /*变量定义 */ printf( 输入三个单精度浮点数 ); scanf( %f%f%f , &x, &y, &z); min x; if( miny) min y; if( minz) min z; printf( 浮点数 %f, %f 中的最小值是 %fn , %f, x, y, z, min); 5.编一个程序,求出所有各位数字的立方和等 于 1099 的 3 位数。 解找出所有各位数字的立方和等于 1099 的
24、3 位整数。 3 位整数是 100 至 999 范围内的整数, 设分别用 a, b, c 存储 3 位数的百位、十位和个位 的数字,程序用三重循环求出 a, b, c 的立方和为 1099 的 3 位数 a*100+b*10 c.程序如下: include main() int a, b, c; /*变量定义 */ for( a 1; a main() int i, a, b, c; /*变量定义 */ for ( i 100; i main() int i, d, n, z, p; /*变量定义 */ n z p 0; for( i 1; i0) p+; else z+; printf( 负
25、数有 %d 个,正数有 %d 个,零有 %d 个。 n , n, p, z); 7.编程序,按下列公式计算 e 的值(精度为 1e-6): e 1+1/1! +1/2! +1/3! +1/n ! + 解按 e 的幂级数展开式计算 e 的值。这是 典型的求级数和计算问题。通常采用逐项计算,并 累计的方法。计算新的项时,可用上一轮循环计算 出 的项,这能提高程序的效率。循环直至当前项的 值小于精度要求结束。程序如下: # include main() double e, t, i; /*变量定义 */ e 0.0; t=1.0; i 1.0; while( t 1.0e-6) e+ t; t/=
26、i; i+= 1.0; printf( e %.6fn , e); 8 8.编程序,按下列公式计算 y 的值(精度为 1e-6): y=1/r*r+1 解按所给公式计算数列的和。类似上一小 题的解,逐项计算并累计。程序如下: # include main() double y, r, t; /*变量定义 */ y 0.0; r 1.0; while( t=1.0/( r*r+1.0) =1.0e-6) y+=t; r+=1.0; printf( y=%.6f n , y); 9.编一个程序显示 ASCII 代码 0x20 至 ox6f 的十 进制数值及其对应字符。 解显示 ASCII 代码为十
27、六进制 0x20 至 ox6f 的字符的十进制代码值与其字符。程序可用一个循 环,让变量 i 顺序地取 0X20 至 OX6f 的值,并逐一 输出其十进制代码和对应的字符,程序如下: # include main() int i, k 0; for( i=0x20; i main() /*用 for 循环 */ int i, k 0; for( i l; i main() /*用 while 循环 */ int i, k=0 ; i=1; while( i main() /*用 do-while 循环 */ int i, k 0 ; i=1; do if( k+%5=0) /*每行五个 */
28、printf( n ); printf( %d*%d=%d , i, i, i*i); i+; while( i. 函数 strlen()是系统提供 的字符串处理函数之一,字符串处理函数的函数原 型说明和它们用到的有关常量 、数据结构等,在系 统提供的头文件 string.h 中定义,所以使用该函数 的程序应在程序开头写上包含命令 #include. 4.下面程序的功能是输出数组 s 中最大元素的 下标,请填空。 main() int k, p ; int s=1, 9, 7, 2, -10, 3; for( p 0, k p; psk) _ printf( %d n , k); 解为要寻找数
29、组中的最大元素的下标,需 先预设 1 个临时最大元素的下标,并顺序逐一考察 数组的元素,当发现当前元素比临时最大元素更大 时,就用当前元素的下标更新临时最大元素下标。 直至考察了数组的全部元素后,这临时最大元素下 标就是数组的最大元素下标。通常预设的最大元素 下标是数组的首元素下标,考察是从首元素开始顺 序向后继元素考察。程序中,存储临时最大元素下 标的变量是 k,变量 p 控制顺序考察的循环控制变 量。当发现当前元素 sp比临时最大元素 sk更大 时,应该用 p 更新 k.所以在空框处应填入代码 k p; 。 5.下面程序的功能是将一个字符串 str 的内容颠 倒过来,请填空。 main()
30、 int i, j, _; char str=1234567 ; for( i 0, j strlen( str) ; i= 0; -i) d ci; printf( %c ,); printf( n ); 解程序中,字符数组 b 存储十六进制的 16 个数字符,整型数组 c 存储译出的十六进制数的各 位数值。从整数 n 译出它的各位十六进制数值,需 采用除 16 取余的方法,即求 n 除 16 的余。得到它 的十六进制的个位数,接着将 n 除以 16.在 n 不等 于 0 的情况下循环,能顺序求出 n 的十六进制的个 位数、十位数、百位数等等。程序中变量 base 已预 置 16,所以在第一
31、个空框处可填代码 n%base。 n当 的十六进制数的个位、十位、百位等数字依次存放 于数组 c 中后,就从最高位至最低位,参照数组 c 的内容 d(以其内容为下标),取十六进制数字符表 中的字符 bd输出。所以在第二个空框处可填入代 码 bd. 4.3 程序分析题 1.阅读程序,写出程序运行结果。, main() static int a3 9, 7, 5, 3, l, 2, 4, 6, 8; int i, j, sl 0, s2 0; for( i 0; i3; i+) for( j 0; j3; j+) if( i j) s1 s1 aij; if( i+j 2) s2 s2 aij;
32、printf( %d n%dn , sl, s2); 解已知数组共有 3 行 3 列,第一行依次是 9, 7, 5;第二行是 3, 1, 2;第三行是 4, 6, 8. 程序引用数组元素的游标变量是 i 和 j, 外循环控制 变量 i 是数组的行下标,内循环控制变量 j 是数组 的列下标。循环体的工作是将数组的某些元素累计 到 sl,某些元素累计到 s2.将行下标 i 和列下标 j 相 同的元素累计到 sl, sl a00 al1 a22.将 行下标 i 与列下标 j 的和为 2 的元素累计到 s2, s2 a02 all a20.所以 sl 是 18, s2 是 10. 程序输出: 18 10 2.说明下列程序的功能。 main() int i, j; float a33, b33, x; for( i 0; i3; i+) for( j 0; j3 ; j+) scanf( %f , &x) aij x; for( i 0; i3; i+) for( j 0; j3; j+) bji aij; for( i=0; i3; i+) printf( n ); for( j 0; j3; j+) printf( %f , bij); printf( n );