1、 1 C 程序设计 练习 题 一、单项选择题 导读:单项选择题要求从给出的四个备选答案中,选出一个最符合题意的答案。在完成习题的过程中,不但要选出正确的答案,而且要清楚不正确的选项错在何处,以加深对概念的理解。对于掌握不准的问题,应该通过上机实验来检验。 (注:选用普通整型数据占用 2 个字节的 c 编译器。如 Turbo C 2.0 、 Win-TC、 Turbo C+ 3.0) 【 1.1】 以下不正确的 C 语言标识符是 _。 A) int B) a_1_2 C) ab1exe D) _x 【 1.2】 以下是正确的 C 语言标识符是 _。 A) #define B) _123 C) %
2、d D) n 【 1.3】 下列四组字符串中都可以用作语言程序标识符的一组是 。 A) print B) iam C) Pxq D) str_l _3d one_half My-book Cpp oodbs tart$it line# pow aBc 3pai His.age while 【 1.4】 下面各选项组中,均是 C 语言关键字的组是 。 A) auto, enum, include B) switch, typedef, continue C) signed, union, scanf D) if, struct, type 【 1.5】 下列不属于 C 语言关键字的是 。 A)
3、default B) register C) enum D) external 【 1.6】 C 语言程序从 main()函数开始执行,所以这个函数要写在 _。 A) 程序文件的开始 B) 程序文件的最后 C) 它所调用的函数 的前面 D) 程序文件的任何位置 【 1.7】 下列关于 C 语言的叙述错误的是 _ A) 大写字母和小写字母的意义相同 B) 不同类型的变量可以在一个表达式中 C) 在赋值表达式中等号 (=)左边的变量和右边的值可以是不同类型 D) 同一个运算符号在不同的场合可以有不同的含义 【 1.8】 在 C 语言中,错误的 int 类型 (长度为 2 字节 )的常数是 。 A)
4、 32768 B) 0 C) 037 D) 0xAF 【 1.9】 执行语句 printf(“%x“, -1); (int 类型 长度为 2 字节 )屏幕显示 _。 A) -1 B) 1 C) -ffff D) ffff 【 1.10】 已知 long i=32768; 执行语句 printf(“%d“, i); 屏幕显示 _。 A) -1 B) -32768 C) 1 D) 32768 【 1.11】 已知 long i=65539; 执行语句 printf(“%d“, i); 屏幕显示 _。 A) 65539 B) -3 C) 3 D) 程序不能执行 【 1.12】 在语言中,整数 -8
5、在内存中的存储形式是 。 2 A) 1111 1111 1111 1000 B) 1000 0000 0000 1000 C) 0000 0000 0000 1000 D) 1111 1111 1111 0111 【 1.13】 语言中字符型 (char)数据在内存中的存储形式是 _。 A) 原码 B) 补码 C) 反码 D) ASCII 码 【 1.14】 将字符 g 赋给字符变量 c,正确的表达式是 。 A) c=147 B) c=“147“ C) c=147 D) c=0147 【 1.15】 下列转义字符中错误 的一个是 _。 A) 000 B) 0014 C) x111 D) 2 【
6、 1.16】 将空格符赋给字符变量 c,正确的赋值语句是 _。 A) c=0 B) c=NULL C) c=0 D) c=32 【 1.17】 已知: char a=70; 则变量 a 中 。 A) 包含 1 个字符 B) 包含 2 个字符 C) 包含 3 个字符 D) 说明非法 【 1.18】 字符串 “EOFn=-61“的长度是 _。 A) 8 B) 9 C) 14 D) 非法字符串 【 1.19】 字符串 “的长度是 _。 A) 0 B) 1 C) 2 D) 非法字符串 【 1.20】 已知: char a; int b; float c; double d; 执行语句 “c=a+b+c
7、+d; “后,变量 c 的数据类型是 。 A) int B) char C) float D) double 【 1.21】 温度华氏和摄氏的关系是 : )32(95 FC 。已知: float C, F; 由华氏求摄氏的正确的赋值表达式是 _。 A) C=5/9(F-32) B) C=5*(F-32)/9 C) C=5/9*(F-32) D) 三个表达式都正确 【 1.22】 逗号表达式 “(a=3*5, a*4), a+15“的值是 _。 A) 15 B) 60 C) 30 D) 不确定 【 1.23】 如果 int a=1, b=2, c=3, d=4; 则条件表达式 “a5 A) 1
8、B) 2 C) 3 D) 程序运行有错误 【 1.42】 已知 char a20=“Beijing“, “shanghai“, “tianjin“, “chongqing“ ; 语句 printf(“%c“, a30); 的输出是 _。 A) B) n C) 不定 D) 数组定义有误 【 1.43】 若用数组名作为函数调用时的实参,则实际上传递给形参的是 。 A) 数组首地址 B) 数组的第一个元素值 C) 数组中全部元素的值 D) 数组元素的个数 【 1.44】 对二维数组的正确说明是 _。 A) int a=1, 2, 3, 4, 5, 6; B) int a2=1, 2, 3, 4, 5
9、, 6; C) int a3=1, 2, 3, 4, 5, 6; D) int a2, 3=1, 2, 3, 4, 5, 6; 【 1.45】 对字符数组 s 赋值 , 不合法的一个是 _。 A) char s=“Beijing“; B) char s20=“beijing“; C) char s20; s=“Beijing“; D) char s20=B, e, i, j, i, n, g; 【 1.46】 对字符数组 str 赋初值, str 不能作为字符串使用的一个是 _。 A) char str=“shanghai“; B) char str=“shanghai“; C) char s
10、tr9=s, h, a, n, g, h, a, i; D) char str8= s, h, a, n, g, h, a, i; 【 1.47】 如果一个变量在整个程序运行期间都存在,但是仅在说明它的函数内是可见的,这个变量的存储类型应该被说明为 _。 A) 静态变量 B) 动态变量 C) 外部变量 D) 内部变量 【 1.48】 在一个 C 源程序文件中 , 若要定义一个只允许在该源文件中所有函数使用的变量,则该变量需要使用的存储类别是 。 A) extern B) register C) auto D) static 【 1.49】 在 C 语言中,函数的数据类型是指 _。 A) 函数返
11、回值的数据类型 B) 函数形参的数据类型 C) 调用该函数时的实参的数据类型 D) 任意指定的数据类型 【 1.50】 已知如下定义的函数: fun1(a) printf(“n%d“, a); 则该函数的数据类型是 _。 A) 与参数 a 的类型相同 B) void 型 C) 没有返回值 D) 无法确定 【 1.51】 定义一个函数实现交换 x 和 y 的值,并将结果正确返回。能够实现此功能的是 _。 A) swapa(int x, int y) B) swapb(int *x, int *y) int temp; int temp; 5 temp=x; x=y; y=temp; temp=x
12、; x=y; y=temp; C) swapc(int *x, int *y) D) swapd(int *x, int *y) int temp; int *temp; temp=*x; *x=*y; *y=temp; temp=x; x=y; y=temp; 【 1.52】 求一个角的正弦函数值的平方。能够实现此功能的函数是 _。 A) sqofsina(float x) return(sin(x)*sin(x); B) double sqofsinb(float x) return(sin(double)x)*sin(double)x); C) double sqofsinc(x) re
13、turn(sin(x)*sin(x); D) sqofsind(float x) return(double(sin(x)*sin(x); 【 1.53】 一个函数内有数据类型说明语句如下: double x, y, z(10); 关于此语句的解释,下面说法正确的是 _。 A) z 是一个数组,它有 10 个元素。 B) z 是一个函数,小括号内的 10 是它的实参的值。 C) z 是一个变量,小括号内的 10 是它的初值。 D) 语句中有错误。 【 1.54】 已知函数定义如下: float fun1(int x, int y) float z; z=(float)x/y; return(z
14、); 主调函数中有 int a=1, b=0; 可以正确调用此函数的语句是 _。 A) printf(“%f“, fun1(a, b); B) printf(“%f“, fun1( C) printf(“%f“, fun1(*a, *b); D) 调用时发生错误 【 1.55】 下面函数的功能是 _。 void a(char s1,char s2) while(*s2+=*s1+) ; A) 字符串比较 B) 字符串复制 C) 字符串连接 D) 字符串反向 【 1.56】 在下列结 论中,只有一个是错误的,它是 _ 。 A) 语言允许函数的递归调用 B) 语言中的 continue 语句,可以
15、通过改变程序的结构而省略 C) 有些递归程序是不能用非递归算法实现的 D) C 语言中不允许在函数中再定义函数 【 1.57】 说明语句 “int (*p)( ); “的含义是 。 6 A) p 是一个指向一维数组的指针变量 B) p 是指针变量,指向一个整型数据 C) p 是一个指向函数的指针,该函数的返回值是一个整型 D) 以上都不对 【 1.58】 设有说明 int (*p)4; 其中的标识符 p 是 。 A) 4 个指向整型变量的指针变量 B) 指向 4 个整型变量的函数指针 C) 一个指向具有 4 个整型元素的一维数组的指针 D) 具有 4 个指向整型变量的指针元素的一维指针数组 【
16、 1.59】 已知: char s10, *p=s, 则在下列语句中,错误的语句是 。 A) p=s+5; B) s=p+s; C) s2=p4; D) *p=s0; 【 1.60】 已知: char s100; int i; 则引用数组元素的错误的形式是 。 A) si+10 B) *(s+i) C) *(i+s) D) *(s+)+i) 【 1.61】 已知: char s6, *ps=s; 则正确的赋值语句是 。 A) s=“12345“; B) *s=“12345“; C) ps=“12345“; D) *ps=“12345“; 【 1.62】 已知: int a43=1, 2, 3,
17、 4, 5, 6, 7, 8, 9, 10, 11, 12; int (*ptr)3=a, *p=a0; 则以下能够正确表示数组元素 a12的表达式是 。 A) *(*(a+1)+2) B) *(*(p+5) C) (*ptr+1)+2 D) *(ptr+1)2) 【 1.63】 已知: int a =1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, *p=a; 则值为 3 的表达式是 。 A) p+=2, *(p+) B) p+=2, *+p C) p+=2, (*p)+ D) p+=2, +*p 【 1.64】 已知: int a=1, 2, 3, 4, y,
18、*p=a; 则执行语句 y = (*+p)-; 之 后 , 数组 a 各元素的值变为 _。 A) 0, 1, 3, 4 B) 1, 1, 3, 4 C) 1, 2, 2, 4 D) 1, 2, 3, 3 变量 y 的值是 _。 A) 1 B) 2 C) 3 D) 4 【 1.65】 已知: int a =1, 3, 5, 7, y , *p= a; 为使变量 y 的值为 3,下列语句正确的是 _。 A) y=+*p+; B) y=+(*p+); C) y=(+*p)+; D) y=(*+p)+; 【 1.66】 已知: int x = 1, 3, 5, 7, 9, 11 , *ptr=x; 则
19、能够正确引用数组元素的语句是 。 A) x B) *(ptr-) C) x6 D) *(-ptr) 【 1.67】 函数的功能是交换变量 x 和 y 中的值,且通过正确调用返回交换的结果。能正确执行此功能的函数是 。 A) void funa (int *x, int *y) B) void funb (int x, int y) int *p; int t; p=x; *x=*y; *y=*p; t=x; x=y; y=t; C) void func (int *x, int *y) D) void func (int *x, int *y) *x=*y; *y=*x; *x=*x+*y;
20、*y=*x-*y; *x=*x-*y; 【 1.68】 有定义如下: struct sk int a; float b; data , *p; 如果 p= 则对于结构变量 data 的成员 a 的正确引用是 _。 7 A)( *) .data.a B) (*p).a C) p-data.a D) p.data.a 【 1.69】 已知: struct st int n; struct st *next; ; static struct st a3=1, 如果下述语句的显示是 2,则对 p 的赋值是 _。 printf(“%d“, +(p-next-n); A) p= B) p= C) p= D
21、) p= 【 1.70】 已知: struct person char name10; int age; class10=“LiMing“, 29, “ZhangHong“, 21, “WangFang“, 22; 下述表达式中,值为 72 的一个是 _。 A) class0-age + class1-age+ class2-age B) class1.name5 C) person1.name5 D) clase-name5 【 1.71】 已知: struct int i; char c; float a; test; 则 sizeof(test)的值是 。 A) 4 B) 5 C) 6
22、D) 7 【 1.72】 已知: union int i; char c; float a; test; 则 sizeof(test)的值是 。 A) 4 B) 5 C) 6 D) 7 【 1.73】 已知: union u_type int i; char ch; float a; temp; 现在执行 “temp.i=266; printf(“%d“, temp.ch)“的结果是 。 A) 266 B) 256 C) 10 D) 1 【 1.74】 若有以下程序段: 8 struct dent int n; int *m; ; int a=1, b=2, c=3; struct dent
23、s3 = 101, struct dent *p=s; 则以下表达式中值为 2 的是 。 A) (p+)-m B) *(p+)-m C) (*p).m D) *(+p)-m 【 1.75】 若有以下说明语句,则对结构变量 pup 中 sex 域的正确引用是 。 struct pupil char name20; int sex; pup, *p; p= A) p.pup.sex B) p-pup.sex C) (*p).pup.sex D) (*p).sex 【 1.76】 以下对结构变量 stul 中成员 age 的非法引用是 。 struct student int age; int nu
24、m; stu1, *p; p= A) stu1.age B) student.age C) p-age D) (*p).age 【 1.77】 若有以下定义和语句: union data int i; char c; float f; a; int n; 则以下语句正确的是 。 A) a=5; B) a=2, a, 1.2; C) printf(“%dn“, a.i); D) n=a; 【 1.78】 已知 enum week sun, mon, tue, wed, thu, fri, satday; 则正确的赋值语句是 _。 A) sun=0; B) san=day; C) sun=mon;
25、 D) day=sun; 【 1.79】 已知 enum color red, yellow=2, blue, white, blackren; 执行下述语句的输出结果是_。 printf(“%d“, ren=white); A) 0 B) 1 C) 3 D) 4 【 1.80】 下述关于枚举类型名的定义中,正确的是 _。 A) enem a= one, two, three ; B) enem a one=9, two=-1, three ; C) enem a=“one“, “two“, “three“; D) enem a “one“, “two“, “three“; 【 1.81】 已
26、知宏定义 #define N 3 #define Y(n) (N+1)*n) 执行语句 z=2*(N+Y(5+1); 后,变量 z 的值是 _。 A) 42 B) 48 C) 52 D) 出错 9 【 1.82】 已知宏定义 #define SQ(x) x*x, 执行语句 printf(“%d“, 10/SQ(3); 后的输出结果是_。 A) 1 B) 3 C) 9 D) 10 【 1.83】 已知宏定义如下: #define PR printf #define NL “n“ #define D “%d“ #define D1 D NL 若程序中的语句是 PR(D1, a); 经预处理后展开为
27、 _。 A) printf(%dn, a); B) printf(“%dn“, a); C) printf(“%d“n“, a); D) 原语句错误 【 单项选择题参考答案 】 【 1.1】 答案 : A 注释: int 是 C 语言的关键字 【 1.2】 答案 : B 【 1.3】 答案: A 【 1.4】 答案: B 注释: include 是预处理命令 ; scanf 是函数名 ; type 不是 C 语言的关键 字。 【 1.5】 答案: D 【 1.6】 答案: D 【 1.7】 答案: A 【 1.8】 答案: A 注释: int 型表示整数的范围是 -32768 32767。 【
28、 1.9】 答案: D 注释:整型常量 -1 在计算机中表示为补码 1111 1111 1111 1111,用十六进制显示这个数时,最左边的 1 不会被解释为符号位,而是与右边其它位共同转换为十六进制数。 【 1.10】 答案: B 注释:长整型数 32768 在计算机内的表示是 1000 0000 0000 0000,以一般整型进行输出时,此数恰是 -32768 的补码。 【 1.11】 答案: C 注释:长整型数 65539 在计算机内的表示是 0001 0000 0000 0000 0011,以一般整型进行输出时,仅将右侧 16 位二进制数转换为十进制数。 【 1.12】 答案: A 注
29、释: C 语言中, int 型的负数是采用补码表示的。 【 1.13】 答案: D 【 1.14】 答案: C 注释:变量 c 是字符型,可用字符常量为它赋值。字符常量必须用单引号括起来,所以 B 是错误的 ; 在单引号或双引号内的反斜线 用于表示转义字符, A 选项在无引号时使用反斜线是错误的 ; C 选项单引号内出现反斜线表示它与后面的数字组成一个转义字符 ; 单引号只允许括起一个字符, D 选项在单引号内出现 4 个字符,是错误的。 【 1.15】 答案: C 【 1.16】 答案: D 注释:空字符和空格符是不同的两个字符,空格符的 ASCII 码值是 32,空字符的 ASCII 值是
30、 0。 【 1.17】 答案: A 【 1.18】 答案: B 10 【 1.19】 答案: A 【 1.20】 答案: C 【 1.21】 答案: B 注释:单纯从 C 语言语法来说,选项 B、 C 都是正确的,但是选项 C 中第一个运算的两个对象都是整型常数,其结果也是整型数 0, 最后的运算结果也就是 0 了。 【 1.22】 答案: C 【 1.23】 答案: A 注释 :将条件表达式增加一个括号,此式变为 ab?a:(cd?c:d),它的运算顺序就清楚了。由于条件运算符的结合性是从右向左,所以括号可以省略。它的运算顺序是先算出右边的条件表达式 “cd?c:d“的值,然后求条件表达式
31、ab?a:3 的值。 【 1.24】 答案: C 【 1.25】 答案: B 【 1.26】 答案: B 注释:当通过一个运算对象即可决定逻辑运算 &的结果时,则对另一个运算对象不做处理。 【 1.27】 答案: D 【 1.28】 答案: B 注释:数组元素在内存中按行排列,此数组的前 3 个元素的值分别是 3、 2、 1,表达 式中虽然数组下标的写法似乎每行有 3 个元素,和定义时的 3 行 2 列不一致,但是 C 语言引用数组元素时是根据数组的首地址和给出的下标进行运算决定元素的地址。题中表达式引用了数组前 3 个元素。 【 1.29】 答案 : A 【 1.30】 答案: C 【 1.
32、31】 答案: C 【 1.32】 答案: D 【 1.33】 答案: D 【 1.34】 答案: C 【 1.35】 答案: D 【 1.36】 答案: C 注释:在 C 语言中, 经常用一个变量来作为逻辑表达式,其含义就是:当变量的值不为 0 时关系成立。 【 1.37】 答案: D 注释: break 语句仅可跳出 switch 语句,不会跳出 while 循环,这是一个死循环。 【 1.38】 答案: A 【 1.39】 答案: C 【 1.40】 答案: C 【 1.41】 答案: D 注释:当除数 y 为 0 时,程序发生溢出错误。 【 1.42】 答案: C 【 1.43】 答案: A 【 1.44】 答案: C 【 1.45】 答案: C 注释:答案 C 的赋值号左侧是数组 s 的首地址,是一个常量,赋值号右侧是一个字符串常量,不可能将一个字符串常量赋给一个地址常量。 【 1.46】 答案: D 注释: D 选项缺少字符串结束标志。