1、1C 语言程序设计试题集及答案目录(按住 CTRL 键点击超链)单项 选择题第 002 页阅读程序题第 018 页程序填空题第 039 页编写程序题第 070 页C 语言程序设计精品课件制作小组2009 年 4 月2一、单项选择题导读:单项选择题要求从给出的四个备选答案中,选出一个最符合题意的答案。本类习题主要检查对 C 语言基本概念的掌握情况,读者可根据学习进度选做部分习题。在完成习题的过程中,不但要选出正确的答案,而且要清楚不正确的选项错在何处,以加深对概念的理解。对于掌握不准的问题,应该通过上机实验来检验。【1.1】以下不正确的 C 语言标识符是 _。A) int B) a_1_2 C)
2、 ab1exe D) _x【1.2】以下是正确的 C 语言标识符是 _。A) #define B) _123 C) %d D) n【1.3】下列四组字符串中都可以用作语言程序标识符的一组是 。 A) print B) iam C) Pxq D) str_l _3d one_half My-book Cpp oodbstart$it line# pow aBc 3pai His.age while【1.4】下面各选项组中,均是 C 语言关键字的组是 。A) auto,enum,include B) switch,typedef ,continueC) signed,union,scanf D)
3、if,struct ,type【1.5】下列不属于 C 语言关键字的是 。 A) 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 语言中,错误的 in
4、t 类型的常数是 。A) 32768 B) 0 C) 037 D) 0xAF【1.9】执行语句 printf(“%x“,-1);屏幕显示_。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;3执行语句 printf(“%d“,i);屏幕显示_。A) 65539 B) -3 C) 3 D) 程序不能执行【1.12】在语言中,整数-8 在内存中的存储形式是 。A) 1111 1111 1111 1
5、000 B) 1000 0000 0000 1000C) 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【1.16】将空格符赋给字符变量 c,正确的赋值语句是_。A) c=0 B) c=NULL C) c=0
6、 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+d;“后,变量 c 的数据类型是 。A) int B) char C) float D) double【1.21】温度华氏和摄氏的关系是: C=-(F-32)。
7、已知: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&+x=57&c=90&c=122B) !(c=57&c=90&c=122)C) c=48&c=65&c=97&c=48&c=65&c=97&c0)&(xy);A) 1 B) 2 C) 3 D) 程序运行有错误【1.49】已知ch
8、ar a20=“Beijing“,“shanghai“,“tianjin“,“chongqing“;语句 printf(“%c“,a30);的输出是_。A) B) n C) 不定 D) 数组定义有误【1.50】若用数组名作为函数调用时的实参,则实际上传递给形参的是 。A) 数组首地址 B) 数组的第一个元素值C) 数组中全部元素的值 D) 数组元素的个数【1.51】对二维数组的正确说明是_。A) int a=1,2,3,4,5,6; B) int a2=1,2,3,4,5,6;C) int a3=1,2,3,4,5,6; D) int a2,3=1,2,3,4,5,6;【1.52】对字符数组
9、s 赋值,不合法的一个是_。A) char s=“Beijing“; B) char s20=“beijing“;C) char s20;s=“Beijing“ ; D) char s20=B,e,i,j,i,n,g;7【1.53】对字符数组 str 赋初值,str 不能作为字符串使用的一个是_。A) char str=“shanghai“;B) char str=“shanghai“; C) char str9=s,h,a,n,g,h,a,i;D) char str8= s,h,a,n,g,h,a,i;【1.54】对函数形参的说明有错误的是_。A) int a(float x,int n)
10、B) int a(float *x,int n)C) int a(float x10,int n) D) int a(float x,int n)【1.55】如果一个变量在整个程序运行期间都存在,但是仅在说明它的函数内是可见的,这个变量的存储类型应该被说明为_。A) 静态变量 B) 动态变量 C) 外部变量 D) 内部变量【1.56】在一个 C 源程序文件中 ,若要定义一个只允许在该源文件中所有函数使用的变量,则该变量需要使用的存储类别是 。A) extern B) register C) auto D) static【1.57】在 C 语言中,函数的数据类型是指 _。A) 函数返回值的数据类
11、型 B) 函数形参的数据类型C) 调用该函数时的实参的数据类型 D) 任意指定的数据类型【1.58】已知如下定义的函数:fun1(a) printf(“n%d“,a);则该函数的数据类型是_。A) 与参数 a 的类型相同 B) void 型C) 没有返回值 D) 无法确定【1.59】定义一个函数实现交换 x 和 y 的值,并将结果正确返回。能够实现此功能的是_。A) swapa(int x,int y) B) swapb(int *x,int *y) int temp; int temp;temp=x;x=y;y=temp; temp=x;x=y;y=temp; C) swapc(int *x
12、,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.60】求一个角的正弦函数值的平方。能够实现此功能的函数是_。A) sqofsina(x) float x; return(sin(x)*sin(x);8B) double sqofsinb(x)float x; return(sin(double)x)*sin(double)x);C) double sqofsinc(x) return(sin(x)*sin(x);D) sqofsind(x)floa
13、t x; return(double(sin(x)*sin(x);【1.61】一个函数内有数据类型说明语句如下:double x,y,z(10);关于此语句的解释,下面说法正确的是_。A) z 是一个数组,它有 10 个元素。B) z 是一个函数,小括号内的 10 是它的实参的值。C) z 是一个变量,小括号内的 10 是它的初值。D) 语句中有错误。【1.62】已知函数定义如下:float fun1(int x,int y) float z;z=(float)x/y;return(z);主调函数中有 int a=1,b=0;可以正确调用此函数的语句是_。A) printf(“%f“,fun1
14、(a,b); B) printf(“%f“,fun1(&a,&b);C) printf(“%f“,fun1(*a,*b); D) 调用时发生错误【1.63】下面函数的功能是_。a(s1,s2)char s1,s2; while(s2+=s1+) ;A) 字符串比较 B) 字符串复制 C) 字符串连接 D) 字符串反向【1.64】在下列结论中,只有一个是错误的,它是 。A) 语言允许函数的递归调用B) 语言中的 continue 语句,可以通过改变程序的结构而省略C) 有些递归程序是不能用非递归算法实现的 D) C 语言中不允许在函数中再定义函数【1.65】已知:int a, *y=&a;则下列
15、函数调用中错误的是 。9A) scanf(“%d“, &a); B) scanf(“%d“, y);C) printf(“%d“, a); D) printf(“%d“, y);【1.66】说明语句“int (*p)( );“ 的含义是 。A) p 是一个指向一维数组的指针变量B) p 是指针变量,指向一个整型数据C) p 是一个指向函数的指针,该函数的返回值是一个整型D) 以上都不对【1.67】设有说明 int (*p)4;其中的标识符 p 是 。A) 4 个指向整型变量的指针变量B) 指向 4 个整型变量的函数指针C) 一个指向具有 4 个整型元素的一维数组的指针D) 具有 4 个指向整型
16、变量的指针元素的一维指针数组【1.68】已知:char s10, *p=s,则在下列语句中,错误的语句是 。A) p=s+5; B) s=p+s; C) s2=p4; D) *p=s0;【1.69】已知:char s100 ;int i ;则引用数组元素的错误的形式是 。A) si+10 B) *(s+i) C) *(i+s) D) *(s+)+i)【1.70】已知:char s6, *ps=s;则正确的赋值语句是 。A) s=“12345“; B) *s=“12345“; C) ps=“12345“; D) *ps=“12345“;【1.71】已知:char a310=“BeiJing“,“
17、ShangHai“,“TianJin“, *pa=a;不能正确显示字符串“ShangHai“的语句是 。A) printf(“%s“,a+1); B) printf(“%s“,*(a+1);C) printf(“%s“,*a+1); D) printf(“%s“,&a10);【1.72】已知:int a43=1,2,3,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.73】已知:int a =1,2
18、,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.74】已知:int a=1,2,3,4, y, *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.75】已知:int a =1,3,5,7, y *p= a;为使变量 y 的值为 3,下列语句正确的是_。A) y=+*p+; B)
19、 y=+(*p+); C) y=(+*p)+; D) y=(*+p)+;10【1.76】已知:int x = 1,3,5,7,9,11 ,*ptr=x;则能够正确引用数组元素的语句是 。A) x B) *(ptr-) C) x6 D) *(-ptr)【1.77】函数的功能是交换变量 x 和 y 中的值,且通过正确调用返回交换的结果。能正确执行此功能的函数是 。A) funa (int *x, int *y) B) funb (int x, int y) int *p; int t;p=x;*x=*y;*y=*p; t=x; x=y;y=t ; C) func (int *x, int *y)
20、D) func (int *x, int *y) *x=*y;*y=*x; *x=*x+*y;*y=*x-*y ;*x=*x-*y; 【1.78】有定义如下:struct sk int a;float b;data ,*p;如果 p=&data;则对于结构变量 data 的成员 a 的正确引用是_。A)(*) .data.a B) (*p).a C) p-data.a D) p.data.a【1.79】已知:struct st int n;struct st *next;static struct st a3=1,&a1,3,&a2,5,&a0,*p;如果下述语句的显示是 2,则对 p 的赋值
21、是_。printf(“%d“,+(p-next-n);A) p=&a0; B) p=&a1; C) p=&a2; D) p=&a3;【1.80】已知:struct person char name10;int age;class10=“LiMing“,29,“ZhangHong“,21,“WangFang“,22;下述表达式中,值为 72 的一个是_。A) class0-age + class1-age+ class2-ageB) class1.name5 C) person1.name5D) clase-name5【1.81】已知:struct int i;11char c;float a;
22、test;则 sizeof(test)的值是 。A) 4 B) 5 C) 6 D) 7【1.82】已知:union int i;char c;float a;test;则 sizeof(test)的值是 。A) 4 B) 5 C) 6 D) 7【1.83】已知: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.84】若有以下程序段:struct dent int n;int *m;int a=1,b=2,c=3;struct
23、dent s3 = 101,&a,102,&b,103,&c ;struct dent *p=s;则以下表达式中值为 2 的是 。A) (p+)-m B) *(p+)-m C) (*p).m D) *(+p)-m【1.85】若有以下说明语句,则对结构变量 pup 中 sex 域的正确引用是 。struct pupil char name20;int sex;pup,*p;p=&pup;A) p.pup.sex B) p-pup.sex C) (*p).pup.sex D) (*p).sex【1.86】以下对结构变量 stul 中成员 age 的非法引用是 。struct student12 i
24、nt age;int num;stu1,*p;p=&stu1;A) stu1.age B) student.age C) p-age D) (*p).age【1.87】若有以下定义和语句:union data int i;char c;float f;a;int n;则以下语句正确的是 。A) a=5; B) a=2,a,1.2; C) printf(“%dn“,a); D) n=a;【1.88】已知:struct sk int a;int age;date,*p;如果要使指针 p 指向 data 中的成员 a,正确的赋值语句是_。A) p = (struct sk *)&data.a; B)
25、 p = (struct sk *)data.a;C) p = &data.a; D) *p = data.a;【1.89】已知 enum week sun,mon,tue,wed,thu,fri,satday;则正确的赋值语句是_。A) sun=0; C) san=day; D) sun=mon; D) day=sun;【1.90】已知 enum color red,yellow=2,blue,white,blackren;执行下述语句的输出结果是_。printf(“%d“,ren=white);A) 0 B) 1 C) 3 D) 4【1.91】已知 enum namezhao=1,qian
26、,sun,liman;执行下述程序段后的输出是_。man=0;switch(man) case 0: printf(“Peoplen“);case 1: printf(“Mann“);case 2: printf(“Womann“);default: printf(“Errorn“);A) People B) Man C) Woman D)Error13【1.92】下述关于枚举类型名的定义中,正确的是_。A) enem a= one,two,three ; B) enem a one=9,two=-1,three ;C) enem a=“one“,“two“,“three“; D) enem
27、a “one“,“two“,“three“;【1.93】语言中标准输入文件 stdin 是指 。A) 键盘 B) 显示器 C) 鼠标 D) 硬盘【1.94】要打开一个已存在的非空文件“file“用于修改,选择正确的语句。A) fp=fopen(“file“, “r“); B) fp=fopen(“file“, “a+“);C) fp=fopen(“file“, “w“); D) fp=fopen(file“, “r+“);【1.95】当顺利执行了文件关闭操作时,fclose 函数的返回值是 。A) -1 B) TRUE C) 0 D) 1 【1.96】fscanf 函数的正确调用形式是 。A)
28、 fscanf (文件指针, 格式字符串, 输出列表);B) fscanf (格式字符串 , 输出列表 , 文件指针);C) fscanf (格式字符串, 文件指针, 输出列表);D) fscanf (文件指针, 格式字符串, 输入列表);【1.97】使用 fgetc 函数,则打开文件的方式必须是 。A) 只写 B) 追加 C) 读或读 /写 D) 参考答案 B 和 C 都正确【1.98】已知宏定义#define N 3#define Y(n) (N+1)*n)执行语句 z=2*(N+Y(5+1);后,变量 z 的值是_。A) 42 B) 48 C) 52 D) 出错【1.99】已知宏定义 #
29、define SQ(x) x*x,执行语句 printf(“%d“,10/SQ(3);后的输出结果是_。A) 1 B) 3 C) 9 D) 10【1.100】已知宏定义如下:#define PR printf#define NL “n“#define D “%d“14#define D1 DNL若程序中的语句是 PR(D1,a);经预处理后展开为_。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【
30、1.4】答案:B注释:include 是预处理命令; scanf 是函数名;type 不是 C 语言的关键字。【1.5】答案:D【1.6】答案:D【1.7】答案:A【1.8】答案:A注释:int 型表示整数的范围是 -3276832767。【1.9】答案:D注释:整型常量-1 在计算机中表示为补码 1111 1111 1111 1111,用十六进制显示这个数时,最左边的 1 不会被解释为符号位,而是与右边其它位共同转换为十六进制数。【1.10】答案:B注释:长整型数 32768 在计算机内的表示是 1000 0000 0000 0000,以一般整型进行输出时,此数恰是-32768 的补码。【1
31、.11】答案:C注释:长整型数 65539 在计算机内的表示是 0001 0000 0000 0000 0011,以一般整型进行输出时,仅将右侧 16 位二进制数转换为十进制数。【1.12】答案:A注释:C 语言中,int 型的负数是采用补码表示的。【1.13】答案:D【1.14】答案:C注释:变量 c 是字符型,可用字符常量为它赋值。字符常量必须用单引号括起来,所以 B 是错误的;在单引号或双引号内的反斜线用于表示转义字符,A 选项在无引号时使用反斜线是错误的;C 选项单引号内出现反斜线表示它与后面的数字组成一个转义字符;单引号只允许括起一个字符,D 选项在单引号内出现 4 个字符,是错误的
32、。【1.15】答案:C【1.16】答案:D注释:空字符和空格符是不同的两个字符,空格符的 ASCII 码值是 32,空字符的 ASCII 值是0。【1.17】答案:A【1.18】答案:B【1.19】答案:A【1.20】答案:C【1.21】答案:B注释:单纯从 C 语言语法来说,选项 B、C 都是正确的,但是选项 C 中第一个运算的两个对象15都是整型常数,其结果也是整型数 0,最后的运算结果也就是 0 了。【1.22】答案:C【1.23】答案:A注释:将条件表达式增加一个括号,此式变为 anext 是 a0的地址,引用其成员 n 再做前增 1 运算,结果就是 2。【1.80】答案:B【1.81
33、】答案:D【1.82】答案:A【1.83】答案:C注释:联合变量 temp 的成员是占用同一存储单元,它的长度是 4 个字节。266 的二进制表示是100001010,存放在存储单元的低端两个字节,如下图:高字节 0 0 0 0 0 0 0 1低字节 0 0 0 0 1 0 1 0引用 temp.ch 进行输出,只取最低的第一个字节。【1.84】答案:D注释:由于结构指针指向了结构数组的 0 号元素,所以表达式(p+)-m 的含义是先取出 m(变量 a 的地址) ,然后指针 p 加 1。表达式*(p+)-m 的含义是先取出 m 的内容(变量 a 的值) ,然后指针 p 再加 1。表达式(*p)
34、.m 的含义是取出 m(变量 a 的地址) 。表达式*(+p)-m 的含义是先将指针 p 加 1,然后再取 m 的内容(变量 b 的值) 。【1.85】答案:D【1.86】答案:B【1.87】答案:C18【1.88】答案:A【1.89】答案:D【1.90】答案:D【1.91】答案:A【1.92】答案:B【1.93】答案:A【1.94】答案:D注释:函数 fopen 中的第二参数是打开模式,“r“模式是只读方式,不能写文件;“a+“模式是读/追加方式,允许从文件中读出数据,但所有写入的数据均自动加在文件的末尾;“w“模式是写方式,允许按照用户的要求将数据写入文件的指定位置,但打开文件后,首先要将
35、文件的内容清空。“r+“模式是读/写方式,不但允许读文件,而且允许按照用户的要求将数据写入文件的指定位置,且在打开文件后,不会将文件的内容清空。本题的要求是“修改“ 文件的内容,因此只能选择答案 D。【1.95】答案:C【1.96】答案:D【1.97】答案:C【1.98】答案:B注释:语句 z=2*(N+Y(5+1)引用了两个宏定义。C 语言是区分字母大小的,第二个宏定义中的N 直接用 3 替换,用 5+1 替换 n,则有 z=2*(3+(3+1)*5+1);结果是 48。注意对于带参数的宏亦是直接的文本替换,此例中 n 用 5+1 去替换,结果是(N+1)*5+1,而不是(N+1)*(5+1
36、)。 【1.99】答案:C注释:宏替换后的结果是 printf(“%d“,10/3*3)。【1.100】答案:C二、 阅读程序题导读:学会阅读程序对于初学者来说很重要,一方面可以巩固所学的语法知识,另一方面通过阅读别人写好的程序来打开自己的思路,就所谓见多识广。读者通过阅读理解程序,从给出的四个备选参考答案中,选择程序的正确输出。如果选择有误,就要认真分析原因,是概念方面的错误还是对程序逻辑理解不对,从而加深对语法规则的理解,提高程序设计能力。程序设计语言是开发程序的一个工具,学习语言的目的是为了编写程序来解决实际问题,所以特别提倡通过实际上机来检验备选答案,增强动手能力。习题基本上是按照教材
37、的章节来安排的,读者可以根据学习的进度选择部分习题。 【2.1】以下程序的输出结果是 。 main( ) float a;a=1/100000000;printf(“%g“,a);A) 0.00000e+00 B) 0.0 C) 1.00000e-07 D) 0【2.2】下面程序的输出结果是_。19#include main( ) int x=10; int x=20;printf (“%d,“, x) ;printf(“%dn“, x);A) 10, 20 B) 20,10 C) 10, 10 D) 20,20【2.3】以下程序的输出结果是_。main() unsigned int n;in
38、t i=-521;n=i;printf(“n=%un“,n);A) n=-521 B) n=521 C) n=65015 D) n=102170103【2.4】以下程序的输出结果是 。 main( ) int x=10, y=10; printf(“%d %dn“, x, y) ;A) 10 10 B) 9 9 C) 9 10 D) 10 9【2.5】以下程序的输出结果是_。main() int n=1;printf(“%d %d %dn“,n,n+,n-);A) 1 1 1 B) 1 0 1 C) 1 1 0 D) 1 2 1【2.6】以下程序的输出结果是_。main() int x=0x0
39、2ff,y=0x0ff00;printf(“%dn“,(x&y)4|0x005f);A) 127 B) 255 C) 128 D) 1 【2.7】以下程序的输出结果是_。main()20 int a=1;char c=a;float f=2.0;printf(“%dn“,(!(a=0),f!=0&c=A);A) 0 B) 1 【2.8】下面程序的输出结果是_。main() int a=1,i=a+1;do a+ ;while( !i+ 3); printf(“%dn“,a);A) 1 B) 2 C) 3 D) 4 【2.9】下面程序的输出结果是_。main() int a=111;a=a00;
40、printf(“%d,%on“,a,a);A) 111,157 B) 0,0 C) 20,24 D) 7,7【2.10】下面程序的输出结果是_。main() char s12= “a book“;printf(“%.4s“,s);A) a book! B) a book!b)a=b;b=c;c=a;printf(“a=%d b=%d c=%dn“,a,b,c);A) a=10 b=50 c=10 B) a=10 b=30 c=10C) a=50 b=30 c=10 D) a=50 b=30 c=50【2.13】以下程序的输出结果是 。 main() int a=0,b=1,c=0,d=20;i
41、f(a) d=d-10;else if(!b)if(!c) d=15;else d=25;printf(“d=%dn“,d);A) d=10 B) d=15 C) d=20 D) d=25【2.14】下面程序的输出结果为 。main() int a=1,b=0;switch(a) case 1: switch (b) case 0: printf(“*0*“); break;case 1: printf(“*1*“); break;case 2: printf(“*2*“); break;A) *0* B) *0*2* C) *0*1*2* D) 有语法错误【2.15】以下程序的输出结果是 。
42、 main() char *s=“12134211“;int v1=0,v2=0,v3=0,v4=0,k;for(k=0;sk ; k+)switch(sk) case 1: v1+;case 3: v3+;case 2: v2+;default: v4+;22printf(“v1=%d, v2=%d, v3=%d, v4=%dn“,v1,v2,v3,v4);A) v1=4,v2=2,v3=1,v4=1 B) v1=4,v2=9,v3=3,v4=1C) v1=5,v2=8,v3=6,v4=1 D) v1=4,v2=7,v3=5,v4=8【2.16】下面程序的输出是 。main() int x=
43、1,y=0,a=0,b=0;switch(x) case 1: switch(y) case 0: a+;break;case 1: b+;break;case 2: a+;b+ ;break;printf(“a=%d,b=%dn“,a,b);A) a=2,b=1 B) a=1,b=1 C) a=1,b=0 D) a=2,b=2【2.17】下面程序的输出是_。main() int num=0;while(nummain() int c;while(c=getchar()!=n)switch(c -2) case 0:case 1: putchar(c+4);case 2: putchar(c+
44、4);break;case 3: putchar(c+3);default: putchar(c+2);break;printf(“n“);A) 888988 B) 668966 C) 88898787 D) 66898787【2.20】下面程序的输出结果是_。main() int k=0;char c=A;do switch(c+) case A: k+;break;case B: k-;case C: k+=2;break;case D: k=k%2;contiue;case E: k=k+10;break;default: k=k/3;k+;while(cmain( ) int i,k,
45、a10,p3;k=5;for(i=0;i“,下面程序的输出是_。#include main() float x,y,z;scanf(“%f,%f“,&x,&y);z=x/y;while(1) if(fabs(z)1.0) x=y;y=z;z=x/y;else break;printf(“%fn“,y); A) 1.500000 B) 1.600000 C) 2.000000 D) 2.40000025【2.24】下面程序的输出结果是_。main() int i,j,x=0;for(i=0;imain( ) int n33, i, j;for(i=0;imain( ) int a45=1,2,4
46、,-4,5,-9,3,6,-3,2,7,8,4;int i,j,n;n=9;i=n/5;j=n-i*5-1;printf(“a%d%d=%dn“, i,j,aij);A) 6 B) -3 C) 2 D) 不确定【2.28】下面程序的输出结果是_。int m33= 1, 2, 3 ;int n33= 1, 2, 3 ;main( ) printf(“%dn“, m10+n00 ); /* */printf(“%dn“, m01+n10 ); /* */ A) 0 B) 1 C) 2 D) 3 A) 0 B) 1 C) 2 D) 3【2.29】下面程序的输出结果是_。#include main(
47、) char s150=“some string *“,s2=“test“;printf(“%sn“, strcat(s1,s2);A) some string * B) testC) some stritest D) some string *test【2.30】下面程序的输出结果是_。#include f(char *s) char *p=s;27while(*p!=0)p+;return(p-s);main() printf(“%dn“,f(“ABCDEF“);A) 3 B) 6 C) 8 D) 0【2.31】下面程序的输出结果是_。#include #include main( ) c