一、C语言概述练习题
选择
1. 一个C程序的执行是从 。 A) 本程序的main函数开始,到main函数结束
B) 本程序文件的第一个函数开始,到本程序文件的最后一个函数结束 C) 本程序文件的第一个函数开始,到本程序main函数结束
D) 本程序的main函数开始,到本程序文件的最后一个函数结束 2. 以下叙述不正确的是 。
A) 一个C源程序必须包含一个main函数 B)一个C源程序可由一个或多个函数组成
C) C程序的基本组成单位是函数 D) 在C程序中,注释说明只能位于一条语句的后面 3. 以下叙述正确的是 。
A) 在对一个C程序进行编译的过程中,可发现注释中的拼写错误 B) 在C程序中,main函数必须位于程序的最前面
C) C语言本身没有输入输出语句 D) C程序的每行中只能写一条语句 4. 一个C语言程序是由 。
A)一个主程序和若干个子程序组成 B) 函数组成 C) 若干过程组成 D) 若干子程序组成
5. 计算机高级语言程序的运行方法有编译执行和解释执行两种,以下叙述中正确的是 。 A) C语言程序仅可以编译执行 B) C语言程序仅可以解释执行 C) C语言程序既可以编译执行又可以解释执行 D) 以上说法都不对 6. 以下叙述中错误的是 。
A) C语言的可执行程序是由一系列机器指令构成的 B)用C语言编写的源程序不能直接在计算机上运行
C)通过编译得到的二进制目标程序需要连接才可以运行
D)在没有安装C语言集成开发环境的机器上不能运行C源程序生成的.exe文件 7. 以下叙述正确的是 。
A) C语言程序是由过程和函数组成的 B) C语言函数可以嵌套调用,例如:fun(fun(x)) C) C语言函数不可以单独编译 D) C语言中除了main函数,其他函数不可作为单独文件形式存在
二、数据类型、运算符与表达式 选择.
1. 若x、i、j、k都是int型变量,则计算下面表达式后,x的值为 x=(i=4,j=16,k=32) A) 4 B) 16 C) 32 D) 52 2. 下列四组选项中,均不是C语言关键字的选项是 。
A)define IF type B)getc char printf C)include case scanf D)while go pow 3. 下列四组选项中,均是不合法的用户标识符的选项是 。
A) W P_0 do B) b-a goto int C) float la0 _A D) -123 abc TEMP 4. 下列四组选项中,均是合法转义字符的选项是 。 A)‘\\”’‘\\\\’‘\\n’ B)‘\\’‘\\017’‘\\”’
C)‘\\018’‘\\f’‘xab’ D)‘\\\\0’‘\\101’‘xlf’ 5. 下面不正确的字符常量是 。
A) “c” B) ‘\\\\’’ C) ‘’ D) ‘K’ 6. 以下叙述不正确的是 。
A) 在C程序中,逗号运算符的优先级最低 B) 在C程序中,MAX和max是两个不同的变量
C) 若a和b类型相同,在计算了赋值表达式a=b后,b中的值将放入a中,而b中的值不变 D) 当从键盘输入数据时,对于整型变量只能输入整型数值,对于实型变量只能输入实型数值 7. 以下叙述正确的是 。 A) 在C程序中,每行只能写一条语句
B) 若a是实型变量,C程序中允许赋值a=10,因此实型变量中允许存放整型数
. . .
.
C) 在C程序中,%是只能用于整数运算的运算符(字符型也可以) D) 在C程序中,无论是整数还是实数,都能被准确无误地表示
8. 已知字母A的ASCII码为十进制数65,且c2为字符型,则执行语句c2=‘A’+‘6’-‘3’后,c2中的值为 。 A) D B) 68 C) 不确定的值 D) C 9. sizeof(float)是 。
A) 一个双精度型表达式 B) 一个整型表达式 C) 一种函数表达式 D) 一个不合法的表达式 10.设C语言中,一个int型数据在存中占2个字节,则unsigned int 型数据的取值围为 。 A) 0~255 B) 0~32767 C) 0~65535 D) 0~2147483647
11.设有说明:char w; int x; float y; double z;则表达式w*x+z-y值的数据类型为 。 A) float B) char C) int D) double 12.设以下变量均为int类型,则值不等于7的表达式是 。
A) (x=y=6,x+y,x+1) B) (x=y=6,x+y,y+1) C) (x=6,x+1,y=6,x+y) D) (y=6,y+1,x=y,x+1) 13.下列变量定义中合法的是 。
A) short _a=015; B) double b=e2.5; C) long do=0xfdaL; D) float 2_and=1e-3; 14.有以下程序
#include { int x=011; printf(\"%d\\n\ }程序运行后的输出结果是 。 A)12 B)11 C)10 D)9 填空 1. 若有以下定义,int m=5,y=2;则计算表达式y+=y-=m*=y后的y值是【1】。-16 2. 在C语言中,一个int型数据在存中占2个字节,则int型数据的取值围为【2】。-32768~32767 3. 若s是int型变量,且s=6,则下面表达式s%2+(s+1)%2的值为【3】。1 4. 若a是int型变量,则下面表达式(a=4*5,a*2),a+6的值为【4】。26 5. 若x和a均是int型变量,则计算表达式(1)后的x值为【5】,计算表达式(2)后的x 值为 【6】。4 12 (1) x=(a=4,6*2) (2) x=a=4,6*2 6. 若a是int型变量,则计算下面表达式a=25/3%3后a的值为【7】。 2 7. 若x和n均是int型变量,且x和n的初值均为5,则计算表达式后x的值为【8】,n的值为 【9】。10 6 x+=n++ //若改为x+=++n 则计算后X为 ,n为 11 6 8. 若有定义:char c=‘\\’;则变量c中包含的字符个数为【10】。1 9. 若有定义:int x=3,y=2;float a=2.5,b=3.5;则下面表达式(x+y)%2+(int)a/(int)b的值为【11】。 1 10.已知字母a的ASCII码为十进制数97,且设ch为字符型变量,则表达式ch=‘a’+‘8’-‘3’ 的值为【12】。 f 三、简单的C程序设计 选择 1. putchar函数可以向终端输出一个 。 A) 整型变量表达式 B) 实型变量值 C) 字符串 D) 字符或字符型变量值 2. printf函数中用到格式符%5s,其中数字5表示输出的字符串占用5列。如果字符串长度大于5, 则输出按方式 B ;如果字符串长度小于5,则输出按方式 C 。 A) 从左起输出该字符串,右补空格 B) 按原字符长从左向右全部输出 C) 右对齐输出该字符串,左补空格 D) 输出错误信息 3. 阅读以下程序,当输入数据的形式为:25,13,10 结果为 。 main() . . . . { int x,y,z; scanf(“%d%d%d”,&x,&y,&z); printf(“x+y+z=%d\\n”,x+y+z); } A) x+y+z=48 B) x+y+z=35 C) x+z=35 D) 不确定值 4. 根据下面的程序及数据的输入和输出形式,程序中输入语句的正确形式应该为 。 main() { char ch1,ch2,ch3; 输入语句 printf(“%c % %c”,ch1,ch2,ch3); } 输出形式:A B C 输入形式:A B C A) scanf(“%c%c%c”,&ch1,&ch2,&ch3); B) scanf(“%c,%c,%c”,&ch1,&ch2,&ch3); C) scanf(“%c %c %c”,&ch1,&ch2,&ch3); D) scanf(“%c%c”,&ch1,&ch2,&ch3); 5. 已知ch是字符型变量,下面不正确的赋值语句是 。 A) ch=‘a’+’b’; B) ch=‘\\0’; C) ch=‘7’+‘9’; D) ch=5+9; 6. 以下关于结构化程序设计的叙述中正确的是 。 A)一个结构化程序必须同时由顺序、分支、循环三种结构组成 B)结构化程序使用goto语句会很便捷 C)在C语言中,程序的模块化是利用函数实现的 D)由三种基本结构构成的程序只能解决小规模的问题 7. 有以下程序 #include {int a1,a2; char c1,c2; scanf(“%d%c%d%c”,&a1,&c1,&a2,&c2); printf(“%d,%c,%d,%c”,a1,c1,a2,c2); }若想通过键盘输入,使得a1的值为12,a2的值为34,c1的值为字符a,c2的值为字符b,程序输出结果是:12,a,34,b则正确的输入格式是(以下_代表空格, 1. 以下的输出结果是【1】。c:dec=120,oct=170,hex=78,ASCII=x main() { char c=‘x’; printf(“c:dec=%d,oct=%o,hex=%x,ASCII=%c\\n”,c,c,c,c); } 2.以下的输出结果是【2】。 main() { int x=1,y=2; printf(“x=%d y=%d * sum * =%d\\n”,x,y,x+y); printf(“10 Squared is : %d\\n”,10*10); } x=1 y=2 * sum * =3 10 Squared is : 100 3. 假设变量a和b均为整型,以下语句可以不借助任何变量把a、b中的值进行交换。请填空。 a+=【3】; b=a-【4】; a-=【5】; b b b 4. 若x为int型变量,则执行以下语句x=7; x+=x-=x+x;后的x 值为【6】。 -14 5. 有一输入语句scanf(“%d”,k);则不能使float类型变量k得到正确数值的原因是【7】和【8】。 格式控制符应为%f;变量k前缺少& 四、逻辑运算与判断选取控制 选择 1. 逻辑运算符两侧运算对象的数据类型 。 . . . . A) 只能是0和1 B) 只能是0或非0正数 C) 只能是整型或字符型数据 D) 可以是任何类型的数据 2. 判断char型变量ch是否为大写字母的正确表达式是 。 A)‘A’<=ch<=‘Z’ B)(ch>=‘A’)&(ch<=‘Z’) C)(ch>=‘A’)&&(ch<=‘Z’) D) (‘A’<= ch)AND(‘Z’>= ch) 3. 若希望当A的值为奇数时,表达式的值为“真”,A的值为偶数时,表达式的值为“假”。则以 下不能满足要求的表达式是 。 A) A%2==1 B) !(A%2==0) C) !(A%2) D) A%2 4. 设有:int a=1,b=2,c=3,d=4,m=2,n=2;执行(m=a>b)&&(n=c>d)后n的值为 。 A) 1 B) 2 C) 3 D) 4 5. 以下程序的运行结果是 。 main() { int a,b,d=241; a=d/100%9; b=(-1)&&(-1); printf(“%d,%d”,a,b); } A) 6,1 B) 2,1 C) 6,0 D) 2,0 6. 已知int x=10,y=20,z=30;以下语句执行后x,y,z的值是 。 if(x>y) z=x; x=y; y=z; A) x=10, y=20, z=30 B) x=20, y=30, z=30 C) x=20, y=30, z=10 D) x=20, y=30, z=20 7. 以下程序的运行结果是 。 main() { int m=5; if(m++>5) printf(“%d\\n”,m); else; printf(“%d\\n”,m--); } A) 4 B) 5 C) 6 D) 7 8. 若运行时给变量x输入12,则以下程序的运行结果是 。 main() { int x,y; scanf(“%d”,&x); y=x>12 ? x+10 : x-12; printf(“%d\\n”,y); } A) 4 B) 3 C) 2 D) 0 9.if语句的基本形式是:if(表达式)语句,以下关于“表达式”值的叙述中正确的是 。 A)必须是逻辑值 B)必须是整数值 C)必须是正数 D)可以是任意合法的数值 10.有以下程序 #include {int a=1,b=0; if(!a) b++; else if(a==0) if(a) b+=2; else b+=3; printf(“%d\\n”,b); }程序运行后的输出结果是 。A)0 B)1 C) 2 D)3 11.有以下程序 #include . . . . {int c=0,k; for(k=1;k<3;k++) switch(k) {default:c+=k; case 2:c++;break; case 4:c+=2;break; } printf(“%d\\n”,c); }程序运行后的输出结果是 。 A)3 B)5 C)7 D)9 五、循环控制 选择1.设有程序段 int k=10; while(k=0)k=k-1; 这下面描述中正确的是_________. a)while循环执行10次 b)循环是无限循环 c)循环体语句一次也不执行 d)循环体语句执行一次 2.语句while(!E);中的表达式!E等价于________. a)E==0 b)E!=1 c)E!=0 d)E==1 3.下面程序段的运行结果是___ c __.循环次数为__ b ___. int n=0; while(n++<=2);printf(\"%d\有语法错 //若改为while(++n<=2);printf(\"%d\结果又如何? 4.下面程序的运行结果是_ __. #include { int num=0; while(num<=2) { num++; printf(\"%d\\n\ } } a)1 b)1 c)1 d)1 2 2 2 3 3 4 5.以下程序段________. x=-1; do{x=x*x; } while(!x); a)是死循环 b)循环执行二次 c)循环执行一次 d)有语法错误 6.若有如下语句 int x=3; do{printf(\"%d\\n\ 则上面程序段______. a)输出的是1 b)输出的是1和-2 c)输出的是3和0 d)是死循 环 7.下面程序的运行结果是______. #include { int y=10; do{y--;} while(--y); printf(\"%d\\n\; }a)-1 b)1 c)8 d)0 8.若i为整型变量,则以下循环执行次数是_____. for(i=2;i==0;)printf(\"%d\ a)无限次 b)0次 c)1次 d)2次 9.执行语句for(i=1;i++<4; );后变量i的值是______. a)3 b)4 c)5 d)不定 10.以下正确的描述是_______. . . . . a)continue语句的作用是结束整个循环的执行 b)只能在循环体和switch语句体使用break语句 c)在循环体使用break语句或continue语句的作用相同 d)从多层循环嵌套中退出时,只能使用goto语句 11.有以下程序 main() { char b,c; int i; b='a'; c='A'; for(i=0;i<6;i++) { if(i%2) putchar(i+b); else putchar(i+c); } printf(\"\\n\"); } 程序运行后的输出结果是______. A)ABCDEF B)AbCdEf C)aBcDeF D)abcdef (二)、填空题 1.下面程序段是从键盘输入的字符中统计数字字符的个数,用换行符结束循环。请填空。 int n=0,c; c=getchar(); while(_ c!=’\\n’ ___) { if(_c>=’0’&&c<=’9’__)n++; c=getchar(); } 2.下面程序的功能是用\"辗转相除法\"求两个正整数的最大公约数。请填空。 #include {int r,m,n; scanf(\"%d%d\ if(m 3.下面程序的运行结果是_____s=254_____. #include {int a,s,n,count; a=2;s=0;n=1;count=1; while(count<=7){n=n*a;s=s+n;++count;} printf(\"s=%d\ } 4.下面程序段的运行结果是__ a=-5_____. i=1;a=0;s=1; do{a=a+s*i;s=-s;i++;}while(i<=10); printf(\"a=%d\ 5.下面程序段的运行结果是__ _8_ ____. i=1;s=3; do{s+=i++; if(s%7==0)continue; . . . . else ++i; }while(s<15); printf(\"%d\ 六、数组 1.以下为一维整型数组a的正确说明是_________. a)int a(10); b)int n=10,a[n]; c)int n; d)#define SIZE 10 scanf(\"%d\ int a[n]; 2.以下对二维数组a的正确说明是________. a)int a[3][]; b)float a(3,4); c)double a[1][4] d)float a(3)(4); 3.若二维数组a有m列,则计算任一元素a[i][j]在数组中位置的公式为_ .(假设a[0][0]位于数组的第一个位置上。) a)i*m+j b)j*m+i c)i*m+j-1 d)i*m+j+1 4.若二维数组a有m列,则在a[i][j]前的元素个数为________. a)j*m+i b)i*m+j c)i*m+j-1 d)i*m+j+1 5.若有以下程序段: …………… int a[]={4,0,2,3,1},i,j,t; for(i=1;i<5;i++) {t=a[i];j=i-1; while(j>=0&&t>a[j]) {a[j+1]=a[j];j--;} a[j+1]=t;} ... ... 则该程序段的功能是_________. a)对数组a进行插入排序(升序) b)对数组a进行插入排序(降序) c)对数组a进行选择排序(升序) d)对数组a进行选择排序(降序) 6.有两个字符数组a、b,则以下正确的输入语句是_______. a)gets(a,b); b)scanf(\"%s%s\ c)scanf(\"%s%s\7.下面程序段的运行结果是_________. char a[7]=\"abcdef\"; char b[4]=\"ABC\"; strcpy(a,b); printf(\"%c\空格 b)\\0 c)e d)f 8.判断字符串s1是否大于字符串s2,应当使用_______. a)if(s1>s2) b)if(strcmp(s1,s2)) c)if(strcmp(s2,s1)>0) d)if(strcmp(s1,s2)>0) 9.下面程序的功能是从键盘输入一行字符,统计其中有多少个单词,单词之间用空格分隔,请选择 填空。 #include char s[80],c1,c2=' '; int i=0,num=0; gets(s); while(s[i]!='\\0') {c1=s[i]; if(i==0)c2=' '; else c2=s[i-1]; if(___)num++; . . . . i++; } printf(\"There are %d words.\\n\} a)c1==' '&&c2==' ' b)c1!=' '&&c2==' ' c)c1==' '&&c2!=' ' d)c1!=' '&&c2!=' ' 10.下面程序的运行结果是_______. #include {char str[]=\"SSSWLIA\ int k; for(k=2;(c=str[k])!='\\0';k++) {switch(c) {case 'I':++k;break; case 'L':continue; default:putchar(c);continue; } putchar('*'); } } a)SSW* b)SW* c)SW*A d)SW 填空 1. 若有定义:double x[3][5];则x数组中行下标的下限为____0____,列下标的上限为_____4_____. 2.下面程序以每行4个数据的形式输出a数组,请填空。 #define N 20 main() {int a[N],i; for(i=0;i printf(\"\\n\"); } 3. 下面程序可求出矩阵a的主对角线上的元素之和,请填空。 main() {int a[3][3]={1,3,5,7,9,11,13,15,17},sum=0,i,j; for(i=0;i<3;i++) for(j=0;j<3;j++) if(_ i==j __)sum=sum+_ a[i][i] _; printf(\"sum=%d\\n\} 4. 当从键盘输入18并回车后,下面程序的运行结果是__10010_____. main() {int x,y,i,a[8],j,u,v; scanf(\"%d\ y=x;i=0; do {u=y/2; a[i]=y%2; . . . . i++;y=u; }while(y>=1); for(j=i-1;j>=0;j--) printf(\"%d\} 5. 下面程序用插入法对数组a进行降序排序。请填空。 main() {int a[5]={4,7,2,5,1}; int i,j,m; for(i=1;i<5;i++) {m=a[i]; j=_ _i-1___; while(j>=0&&m>a[j]) {_ a[j+1]=a[j]__; j--; } _ a[j+1]___=m; } for(i=0;i<5;i++) printf(\"%d \ printf(\"\\n\"); } 6. 下面程序的功能是在三个字符串中找出最小的,请填空。 #include {char s[20],str[3][20]; int i; for(i=0;i<3;i++)gets(str[i]); strcpy(s,__ str[0]__); if(strcmp(s,str[1])<0)strcpy(s,str[1]); if(strcmp(str[2],s)<0)strcpy(s,str[2]); printf(\"%s\\n\_s ___); } 7. 下面程序的运行结果是_#&*&%__. #include {char s[]=\"ABCCDA\"; int k; char c; for(k=1;(c=s[k])!='\\0';k++) {switch(c) {case 'A':putchar('%');continue; case 'B':++k;break; default:putchar('*'); case 'C':putchar('&');continue; } putchar('#'); } } . . . . 七、函数 选择 1.以下正确的说法是_________. 建立函数的目的之一是 a)提高程序的执行效率 b)提高程序的可读性 c)减少程序的篇幅 d)减少程序文件所占存 2.以下正确的函数定义形式是________. a)double fun(int x,int y) b)double fun(int x; int y) c)double fun(int x, int y); d)double fun(int x,y); 3.C语言规定,简单变量做实参时,它和对应形参之间的数据传递方式为______. A)地址传递 B)单向值传递 C)由实参传给形参,再由形参传回给实参 D)由用户指定传递方式 4.C语言允许函数值类型缺省定义,此时该函数值隐含的类型是______. a)float b)int c)long d)double 5.已有以下数组定义和f函数调用语句,则在f函数的说明中,对形参数组array的错误定义方式为_______. int a[3][4]; f(a); a)f(int array[][6]) b)f(int array[3][]) c)f(int array[][4]) d)f(int array[2][5]) 6.以下程序的正确运行结果是_________. #include {extern int x,y; int a=15,b=10; x=a-b; y=a+b; } int x,y; main() { int a=7,b=5; x=a+b; y=a-b; num(); printf(\"%d,%d\\n\ } a)12,2 b)不确定 c)5,25 d)1,12 有以下程序: #include { static int x=1; x+=1; return x; } main() { int i,s=1; for(i=1;i<=5;i++) s+=fun(); printf(“%d\\n”,s); } 程序运行后的输出结果是__ __ A)11 B)21 C)6 D)120 填空 1.以下程序的运行结果是___ __ max is 2 #include {int a=1,b=2,c; . . . . c=max(a,b); printf(\"max is %d\\n\ } int max(int x,int y) {int z; z=(x>y)?x:y; return(z); } 2.函数gongyu的作用是求整数num1和num2的最大公约数,并返回该值。请填空。 gongyu(int num1,int num2) {int temp,a,b; if(num1(__ < __) num2) {temp=num1;num1=num2;num2=temp;} a=num1;b=num2; while(_ !b __) {temp=a%b;a=b;b=temp;} return(a); } 3.以下程序的运行结果是__ A+B=9___. #include { int a=4,b=5,c; c=plus(a,b); printf(\"A+B=%d\\n\ } int plus(int x,int y) {int z; z=x+y; return(z); } 4.以下程序的运行结果是_______. main() {incx(); incy(); incx(); incy(); incx(); incy(); } incx() { int x=0; printf(\"x=%d\\} incy() {static int y=0; printf(\"\\ny=%d\\n\} 八、编译预处理 选择 1.以下叙述中正确的是________. a)在程序的一行上可以出现多个有效的预处理命令行 b)使用带参的宏时,参数的类型应与宏定义时的一致 c)宏替换不占用运行时间,只占用编译时间 . . . x=1 y=1 x=1 y=2 x=1 y=3 . d)在以下定义中C R是称为“宏名”的标识符 #define C R 2.以下程序的运行结果是________. #define MIN(x,y) (x)<(y)?(x):(y) main() {int i=10,j=15,k; k=10*MIN(i,j); printf(\"%d\\n\ } a)10 b)15 c)100 d)150 3.若有宏定义如下: #define X 5 #define Y X+1 #define Z Y*X/2 则执行以下printf语句后,输出结果是_______. int a;a=Y; printf(\"%d\\n\ printf(\"%d\\n\ a)7 b)12 c)12 d)7 6 6 5 5 4.请读程序: #include int a=3,b=4,c; c=MUL(a++,b++); printf(\"%d\\n\ } 上面程序的输出结果是__________. a)12 b)15 c)20 d) 16 5.有以下程序 #include {int a=3,s,t; s=f(a+1); t=f((a+1)); printf(“%d,%d\\n”,s,t); }程序运行后的输出结果是______. A)10,64 B)10,10 C)64,10 D)64,64 九、指针 一、选择题 1.变量的指针,其含义是指该变量的________. a)值 b)地址 c)名 d)一个标志 2.若有语句int *point,a=4;和point=&a;下面均代表地址的一组选项是__ ___. a)a,point,*&a b)&*a,&a,*point c)*&point,*point,&a d)&a,&*point ,point 3.若有说明;int *p,m=5,n;以下正确的程序段的是________. a)p=&n; b)p=&n; c)scanf(\"%d\d)p=&n; scanf(\"%d\4.下面程序段的运行结果是________. . . . . char *s=\"abcde\"; s+=2;printf(\"%s\ a)cde b)字符'c' c)字符'c'的地址 d)无确定的输出结果 5.设p1和p2是指向同一个字符串的指针变量,c为字符变量,则以下不能正确执行的赋值语句是_______. a)c=*p1+*p2; b)p2=c c)p1=p2 d)c=*p1*(*p2); 6.以下正确的程序段是________. a)char str[20]; b)char *p; c)char str[20]; d)char str[20],*p=str; scanf(\"%s\7.若有说明语句 char a[]=\"It is mine\"; char *p=\"It is mine\"; 则以下不正确的叙述是________. a)a+1表示的是字符t的地址 b)p指向另外的字符串时,字符串的长度不受限制 c)p变量中存放的地址值可以改变 d)a中只能存放10个字符 8.下面程序的运行结果是_______. #include char *s1=\"AbDeG\"; char *s2=\"AbdEg\"; s1+=2;s2+=2; printf(\"%d\\n\ } a)正数 b)负数 c)零 d)不确定的值 9.下面程序的运行结果是_______. #include while(s1 p=\"1234567\"; fun(p,strlen(p)); puts(p); } a)7654321 b)1714171 c)1711717 d)7177171 10.若有以下定义,则对a数组元素的正确引用是_________. int a[5],*p=a; a)*&a[5] b)a+2 c)*(p+5) d)*(a+2) 11.若有定义:int a[2][3],则对a数组的第i行j列元素地址的正确引用为______. a)*(a[i]+j) b)(a+i) c)*(a+j) d)a[i]+j 12.若有以下定义,则p+5表示_______. int a[10],*p=a; a)元素a[5]的地址 b)元素a[5]的值 c)元素a[6]的地址 d)元素a[6]的值 二、填空题 1.以下程序的功能是:通过指针操作,找出三个整数中的最小值并输出。请填空。 #include \"stdio.h\" main() {int *a,*b,*c,num,x,y,z; a=&x;b=&y;c=&z; printf(\"输入3个整数:\"); . . . . scanf(\"%d%d%d\ printf(\"%d,%d,%d\\n\ num=*a; if(*a>*b)__ num=*b ___; if(num>*c)___ num=*c __; printf(\"输出最小整数:%d\\n\ } 2.下面程序段的运行结果是__ hELLO ___. char s[80],*sp=\"HELLO!\"; sp=strcpy(s,sp); s[0]='h'; puts(sp); 3.下面程序段的运行结果是__ef___. char str[]=\"abc\\0def\\0ghi\ printf(\"%s\ 4.下面程序的功能是将两个字符串s1和s2连接起来。请填空。 #include {char s1[80],s2[80]; gets(s1); gets(s2); conj(s1,s2); puts(s1); } conj(char *p1,char *p2) {char *p=p1; while(*p1)_ p1++__; while(*p2){*p1=_ *p2___;p1++;p2++;} *p1='\\0'; } 5.若有定义:int a[]={2,4,6,8,10,12},*p=a;则*(p+1)的值是___4___. *(a+5)的值是____12_____. 6.若有以下定义:int a[2][3]={2,4,6,8,10,12};则a[1][0]的值是__8___. *(*(a+1)+0))的值是___8____. 7.以下程序将数组a中的数据按逆序存放,请填空。 #define M 8 main() {int a[M],i,j,t; for(i=0;i for(i=0;i (3)*(*_ (a+i)+j ___); . . . . (4)(*(a+i))[j] (5)*(_ &a[0][0]__+5*i+j) 9.下面程序的运行结果是_________. main() Coble {char *a[]={\"Pascal\ dBase char **p; C language int j; Pascal p=a+3; for(j=3;j>=0;j--)printf(\"%s\\n\ } 十、位运算 一、 填空题 1.sizeof(float)是______. a)一种函数调用 b)一个不合法的表示形式 c)一个整型表达式 d)一个浮点表达式 2.以下叙述中不正确的是__________. a)表达式a&=b等价于a=a&b b)表达式a|=b等价于a=a|b c)表达式a!=b等价于a=a!b d)表达式a^=b等价于a=a^b 4.若x=2,y=3,则x&y的结果是_________. a)0 b)2 c)3 d)5 5.在位运算中,操作数每左移一位,则结果相当于________. a)操作数乘以2 b)操作数除以2 c)操作数除以4 d)操作数乘以4 十一、文件 选择 1.系统的标准数入文件是指_________. a)键盘 b)显示器 c)软盘 d)硬盘 2.若执行fopen函数时发生错误,则函数的返回值是___ ___.a)地址值 b)0 c)1 d)EOF 3.若要用fopen函数打开一个新的二进制文件,该文件要既能读也能写,则文件方式字符串应是______. a)\"ab+\" b)\"wb+\" c)\"rb+\" d)\"ab\" 4.fscanf函数的正确调用形式是________. a)fscanf(fp,格式字符串,输出表列) b)fscanf(格式字符串,输出表列,fp); c)fscanf(格式字符串,文件指针,输出表列); d)fscanf(文件指针,格式字符串,输入表列); 5.fgetc函数的作用是从指定文件读入一个字符,该文件的打开方式必须是__ _. a)只写 b)追加 c)读或读写 d)答案b和c都正确 6.函数调用语句:fseek(fp,-20L,2);的含义是_______. a)将文件位置指针移到距离文件头20个字节处 b)将文件位置指针从当前位置向后移动20个字节 c)将文件位置指针从文件末尾处后退20个字节 d)将文件位置指针移到离当前位置20个字节处 7.利用fseek函数可实现的操作_________. a)fseek(文件类型指针,起始点,位移量); b)fseek(fp,位移量,起始点); c)fseek(位移量,起始点,fp); d)fseek(起始点,位移量,文件类型指针); 8.在执行fopen函数时,ferror函数的初值是_______. a)TURE b)-1 c)1 d)0 . . . 因篇幅问题不能全部显示,请点此查看更多更全内容