您的当前位置:首页正文

C语言各章节复习试题(带答案)

2021-02-04 来源:爱go旅游网
.

一、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 main()

{ 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 main()

{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则正确的输入格式是(以下_代表空格,代表回车) A)12a34b B)12_a_34_b C)12,a,34,b D)12_a34_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 main()

{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 main()

. . .

.

{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 main()

{ 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 main()

{ 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 main()

{int r,m,n;

scanf(\"%d%d\ if(mwhile(r){m=n;n=r;r=__ m%n ____;} printf(\"%d\\n\ }

3.下面程序的运行结果是_____s=254_____. #include main()

{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 main() {

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 main()

{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;iscanf(\"%d\&a[i] __); for(i=0;i{if (____i%4==0_____) _ printf(“\\n”);___ printf(\"%3d\ }

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 #include main()

{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 main()

{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 void num()

{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 int f()

{ 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 max(int,int); main()

{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=5;int b=7; int plus(int ,int ); void main()

{ 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 #define MUL(x,y) (x)*y main() {

int a=3,b=4,c; c=MUL(a++,b++); printf(\"%d\\n\ }

上面程序的输出结果是__________. a)12 b)15 c)20 d) 16 5.有以下程序

#include #define f(x) x*x*x main()

{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 #include main() {

char *s1=\"AbDeG\"; char *s2=\"AbdEg\"; s1+=2;s2+=2;

printf(\"%d\\n\

} a)正数 b)负数 c)零 d)不确定的值 9.下面程序的运行结果是_______. #include #include fun(char *w,int n) {char t,*s1,*s2; s1=w;s2=w+n-1;

while(s1main() {char *p;

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 main()

{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;it=*(a+i); *(a+i)=*(a+j);*(a+j)=t; i++;j--; }

for(i=0;i8.若有定义:int a[3][5],i,j;(且0<=i<3,0<=j<5),则a数组中任一元素可用 五种形式引用。它们是: (1)a[i][j] (2)*(a[i]+j)

(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

. . .

因篇幅问题不能全部显示,请点此查看更多更全内容