《谭浩强C语言程序设计习题集(126页).doc》由会员分享,可在线阅读,更多相关《谭浩强C语言程序设计习题集(126页).doc(128页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、-谭浩强C语言程序设计习题集-第 128 页目录重要 次重要 重复或欲删除 基础第一章 C语言概述1.1 选择题1.2 填空题第二章 数据类型、运算符与表达式2.1 选择题2.2 填空题第三章 最简单的C程序设计3.1 选择题3.2 填空题第四章 逻辑运算和判断选取控制4.1 选择题4.2 填空题4.3 编程题第五章 循环控制5.1 选择题5.2 填空题5.3 编程题第六章 数组6.1 选择题6.2 填空题6.3 编程题第七章 函数7.1 选择题7.2 填空题7.3 编程题第八章 编译预处理8.1 选择题8.2 填空题8.3 编程题第九章 指针9.1 选择题9.2 填空题第一章 C语言概述1.
2、1 选择题一个C程序的执行是从 。A)本程序的main函数开始,到main函数结束B)本程序文件的第一个函数开始,到本程序文件的最后一个函数结束C)本程序的main函数开始,到本程序文件的最后一个函数结束D)本程序文件的第一个函数开始,到本程序main函数结束参考答案:A参考分析:C语言总是从main函数开始,main函数结束。但是C语言中存在一个exit(0)函数,它可以使得程序在任何时候、任何位置结束程序的运行。如果不考虑exit(0)等函数的特殊作用,C则总是在main函数结束。以下叙述正确的是 。A)在C程序中,main函数必须位于程序的最前面B)在C程序的每一行只能写一条语句C)C语
3、言本身没有输入输出语句D)在对一个C程序进行编译的过程中,可发现注释中的拼写错误参考答案:C参考分析:C程序对main函数的位置没有任何要求;其书写格式自由,一行可以写多条语句,一条语句(多关键字语句)可以写在多行;C语言忽略注释,把注释看作是一个空格,不会对注释中的内容进行语法检查。因此,如果注释中存在错误,系统是不可能发现的。另外,C语言的I/O操作均通过函数实现,系统本身未提供相应的语句。A)一个C源程序可由一个或多个函数组成B)一个C源程序必须包含一个main函数C)C程序的基本组成单位是函数D)在C程序中,注释说明只能位于一条语句的后面参考答案:D参考分析:C语言中,注释语句的位置是
4、任意的,当然,它不能破坏标识符的完整性。C语言只是将一个注释看作是一个空格,因此对注释内的任何错误都不作检查。1.4 C语言规定:在一个源程序中,main函数的位置 。A)必须在最开始 B)必须在系统调用的库函数的后面C)可以任意 D)必须在最后参考答案:C一个C语言程序是由 。A)一个主程序和若干个子程序组成 B)若干函数组成C)若干过程组成 D)若干子程序组成参考答案:B参考分析:通常许多语言程序由主程序和子程序构成,但是C语言是函数式语言,整个程序由众多函数组成。尽管有时习惯上称main函数为主程序,显然,严格地讲还是B更为符合C语言的规则。1.2 填空题1.6C源程序的基本单位是【 】
5、。参考答案:函数1.7一个C源程序中至少应包括一个【 】。参考答案:main()函数1.8在一个C源程序中,注释部分两侧的分界符分别为【1】和【2】。参考答案:【1】/* 【2】*/1.9在C语言中,输入操作是由库函数【1】完成的,输出操作是由库函数【2】完成的。参考答案:【1】scanf 【2】printf第二章 数据类型、运算符与表达式2.1 选择题C语言中(以16位PC机为例),各数据类型的存储空间长度的排列顺序为 。A)charintlong=floatdouble B)char=intlong=floatdoubleC)charintlong=float=double D)char=
6、int=long=floatdouble参考答案:A分析:在不同的计算机系统中,不同的C语言系统中,其各种数据类型所占据的存储空间是不同的,但是有一个总的原则,即:char=short=int=long= floatyx。2.36 若有代数式|x3+lgx|,则正确的C语言表达式是 。A)fabs(x*3+log10(x)B)abs(pow(x,3)+log10(x)C)abs(pow(x,3.0)+log10(x)D)fabs(pow(x,3.0)+log10(x)参考答案:D参考分析:以上两题均未说明x,y的类型,从表达式的性质可分析隐含为实型,因此应使用fabs。在C语言中,char型数
7、据在内存中的存储形式是 。A)补码 B)反码 C)原码 D)ASCII码参考答案:D参考分析:计算机系统不能存储字符本身,存储的是字符的ASCII码。设变量n为float,m为int类型,则以下能实现将n中的数值保留小数点后两位,第三位进行四舍五入的表达式是 。A)n=(n*100+0.5)/100.0 B)m=n*100参考答案:B参考分析:m=n*100+0.5赋值过程中有实型转整型的自动转换。2.39表达式18/4*sqrt(4.0)/8值的数据类型为 。A)int B)float C)double D)不确定参考答案:C参考分析:表达式的类型由表达式结果的类型决定。2.40设C语言中,
8、一个int型数据在内存中占2个字节,则unsigned int型数据的取值范围为 。A)0-255 B)0-32767 C)0-65535 D)0-2147483647参考答案:C参考分析:各种数据类型的取值范围是由其字长决定,字长确定的情况下,有符号数与无符号数的范围应当容易计算得知。2.41设有说明:char w;int x;float y;double z;则表达式w*x+z-y值的数据类型为 。A)float B)char C)int D)double参考答案:D参考分析:表达式的类型由表达式结果的类型决定。虽然本题各变量没有具体的变量值,由于参与运算的变量中z变量为double型,表
9、达式计算的结果肯定为double型。2.42若有以下定义,则能使值为3的表达式是 。int k=7,x=12;A)x%=k%=5 B)x%=k-k%5C)x%=(k-k%5) D)(x%=k)-(k%=5)参考答案:D参考分析:A的值为0,B、C两个表达式相同,值为2,只有D的值为3。2.43设以下变量均为int类型,则值不等于7的表达式是 。A)x=y=6,x+y,x+1 B)x=y=6,x+y,y+1C)x=6,x+1,y=6,x+y D)y=6,y+1,x=y,x+1参考答案:C参考分析:经计算可知,只有C的值为12,不为7。2.2 填空题2.44 在C语言中(以16位PC机为例),一个
10、char型数据在内存中所占的字节数为【1】;一个int型数据在内存中所占的字节数为【2】。参考答案:【1】1 【2】22.45 在C语言中(以16位PC机为例),一个float型数据在内存中所占的字节数为【1】;一个double型数据在内存中所占的字节数为【2】。参考答案:【1】4 【2】82.46 若有以下定义,int m=5,y=2;则计算表达式y+=y-=m*=y后y的值是【 】。参考答案:162.47 设C语言中,一个int型数据在内存中占2各字节,则int型数据的取值范围为【 】。参考答案:-32768327672.48 在C语言中的实型变量分为两种类型,它们是【1】和【2】。参考答
11、案:【1】float 【2】double C语言所提供的基本数据类型包括:单精度型、双精度型、【1】、【2】和【3】。参考答案:字符型 整型 枚举参考分析:基本类型又称简单类型,若分为四种则为字符、整型、实型和枚举,若分为五种,则将实型分为单精度型和双精度型两种。 若s是int型变量,则表达式s%2+(s+1)%2的值为【 】。参考答案:1参考分析:无论s是奇数还是偶数表达式的值只能是1。 若a是int型变量,则表达式(a=4*5,a*2),a+6的值为【 】。参考答案:26 若x和a均是整型变量,则计算表达式(1)后的x值为【1】,计算表达式(2)后x的值为【2】。(1)x=(a=4,6*2
12、)(2)x=a=4,6*2参考答案:【1】12 【2】42.53 若a、b和c均是int型变量,则计算表达式a=(b=4)+(c=2)后,a的值为【1】,b的值为【2】,c的值为【3】。参考答案:【1】6 【2】4 【3】22.54 若a是int 型变量,且a的初值为6,则计算表达式a+=a-=a*a后a的值为【 】。参考答案:602.55 若a是int型变量,则计算表达式a=25/3%3后a的值为【 】。参考答案:22.56 若x和n均是int型变量,且x和n的初值均为5,则计算表达式x+=n+后x的值为【1】,n的值为【2】。参考答案:【1】10 【2】62.57 若有定义:int b=7
13、;float a=2.5,c=4.7;则表达式a+(int)(b/3*(int)(a+c)/2)%4的值为【 】。参考答案:2.58 若有定义:int a=2,b=3;float x=3.5,y=2.5;则表达式(float)(a+b)/2+(int)x%(int)y的值为【 】。参考答案:2.59 若有定义:char c=010;则变量c中包含的字符个数为【 】。参考答案:12.60 若有定义:int x=3,y=2;float a=2.5,b=3.5;则表达式(x+y)%2+(int)a/(int)b的值为【 】。参考答案:12.61 若有定义:int x=12,n=5;则计算表达式x%=
14、(n%=2)后x的值为【 】。参考答案:02.62 若有定义:int a,b;表达式a=2,b=5,a+,b+,a+b的值为【 】。参考答案:92.63 C语言中的标识符只能由三种字符组成,它们是【1】、【2】和【3】。参考答案:【1】字符 【2】数字 【3】下划线 已知字母a的ASCII码为十进制数97,且设ch为字符型变量,则表达式ch=a+8-3的值为【 】。参考答案:f参考分析:表达式计算中取各个字符的ASCII码值进行计算,但ch的值是以计算结果为码值的字符。2.65 把以下多项式写成只含七次乘法运算,其余皆为加、减运算的表达式为【 】。参考答案:(5*x+3)*x-4)*x+2)*
15、x+1)*x-6)*x+1)*x+102.66 若double x=3.0,y=2.0;则表达式pow(y,fabs(x)的值为【 】。参考答案:2.67 若有定义:int e=1,f=4,g=2;float m=10.5,n=4.0,k;则计算表达式k=(e+f)/g+ sqrt(double)n)*1.2/g+m后k的值是【 】。参考答案:2.68 表达式8/4*(int)2.5/(int)(1.25*(3.7+2.3)值的数据类型为( )。参考答案:int型 表达式pow(2.8,sqrt(double(x)值的数据类型为【 】。参考答案:double型 假设m是一个三位数,从左到右用a
16、、b、c表示各位的数字,则从左到右各个数字是bac的三位数表达式是【 】。参考答案:m/10%10*100+m/100*10+m%10参考分析:数字各个位的分离可以先整除再取余,也可以先取余再整除。第三章 最简单的C程序设计3.1 选择题3.1 putchar函数可以向终端输出一个 。A)整型变量表达式 B)实型变量值C)字符串 D)字符或字符型变量值参考答案:D参考分析:putchar函数的作用是输出一个字符,可以是常量或变量。以下程序的输出结果是 。printf(n*s1=%15s*,chinabeijing); printf(n*s2=%-5s*,chi); A)*s1=chinabei
17、jing* B)*s1=chinabeijing*s2=*chi* *s2=chi* C) *s1=chinabeijing* D) * s1=chinabeijing*s2=chi* *s2=chi*参考答案:D参考分析:-:数据左齐,右补空格。3.3 printf函数中用到格式符%5s,其中数字5表示输出的字符串占用5列。如果字符串长度大于5,则输出按方式 【1】 ;如果字符串长度小于5,则输出按方式 【2】 。A)从左起输出该字符串,右补空格 B)按原字符串长从左向右全部输出C)右对齐输出该字符串,左补空格 D)输出错误信息参考答案:【1】B 【2】C已有定义int a=-2;和输出语句
18、:printf(%8lx,a);以下正确的叙述是 。A)整型变量的输出格式符只有%d一种B)%x是格式符的一种,它可以适用于任何一种类型的数据C)%x是格式符的一种,其变量的值按十六进制输出,但%8lx是错误的D)%8lx不是错误的格式符,其中数字8规定了输出字段的宽度参考答案:D参考分析:答案B基本上是正确的,但是%x不能正确的输出长整型数据。以下C程序正确的运行结果是 。main() long y=-43456;printf (y=%-8ldn,y);printf (y=%-08ldn,y);printf (y=%08ldn,y);printf (y=%+8ldn,y);A)y=-4345
19、6 B)y=-43456y=-43456 y=-43456y=-0043456 y=-0043456y=-43456 y=+-43456C)y=-43456 D) y=-43456y=-43456 y=-0043456y=-0043456 y=00043456y=-43456 y=+43456参考答案:C参考分析:0:数据左侧必须充满,给定数据不足时,前面补0。+:数据前面显示符号位。以下C程序正确运行的结果是 。main() int y=2456;printf(y=%3on,y);printf(y=%8on,y);printf(y=%#8on,y);A)y=2456 B)y=4630y=24
20、56 y=4630y=#2456 y=#4630C)y=2456 D)y=4630y=2456 y=4630y=02456 y=04630参考答案:D参考分析:#要求输出数据的类型特征符号。main()long y=23456;printf(y=%3lxn,y);printf(y=%8lxn,y);printf(y=%#8lxn,y);A)y=5ba0 B)y=5ba0y=5ba0 y=5ba0y=0x5ba0 y=0x5ba0C)y=5ba0 D)y=5ba0y=5ba0 y=5ba0y=0x5ba0 y=#5ba0参考答案:A分析:长整型数据输出应当加修正字符l,如果不加l仅能输出数据的低
21、两个字节,高字节数据不能输出。 若x,y均定义为int型,z定义为double型,以下不合法的scanf函数调用语句是 。A)scanf(%d%lx,%le,&x,&y,&z);B)scanf(%2d*%d%lf,&x,&y,&z);C)scanf(%x%*d%o,&x,&y);D)scanf(%x%o%6.2f,&x,&y,&z);参考答案:D参考分析:A)首先读第一个十进制数赋给变量x,读第二个长十六进制数赋给变量y(此时有自动赋值转换),再读入格式规定的第二和第三个数据间的间隔符号逗号,最后读入第三个double型数据赋给变量z。B)首先读入2个宽度的十进制数赋给变量x,再读入格式规定的
22、第一和第二数据间的间隔符号星号,然后读入第二个十进制整数赋给变量y,然后读入第三个double型数据赋给变量z。C)读入第一个十六进制数赋给变量x,然后虚读一个十进制数不赋给任何变量,最后读入一个八进制数赋给变量y。D)6.2f不符合格式规定,即不能规定读入数据的小数点后的数字位数。 已有如下定义和输入语句,若要求a1,a2,c1,c2的值分别为10,20,A和B,当从第一列开始输入数据时,正确的数据输入方式是 。int a1,a2;char c1,c2;scanf(%d%c%d%c,&a1,&c1,&a2,&c2);A)10A20B B)10A20BC)10A20B D)10A20B参考答案:A 已有定义int x;float y;且执行scanf(%3d%f,&x,&y);语句时,从第一列开始输入数据12345678,则x的值为 ,y的值为 。 A)12345 B)123 C)45 D)345参考答案:B B参考分析:读取数据格式中规定域宽时,系统仅读取指定宽度的数据。 已有如下定义和输入语句,若要求a1,a2,c1,c2的值分别为10,20,A和B,当从第一列开始输入数据时,正确的数据输入方式是 。int a1,a2;char c1,c2;scanf(%d%d,&a1,&a2);scanf(%c%c,&c1,&c2);A)1020AB B)1020CR