9月计算机二级《C语言》上机考题及答案

Python013

9月计算机二级《C语言》上机考题及答案,第1张

1、以下选项中属于C语言的数据类型是( )。

A. 复合型

B. 双精度型

C. 逻辑型

D. 集合型

2、以下说法中正确的是( )。

A. C语言程序总是从第一个的函数开始执行

B. 在C语言程序中,要调用的函数必须在main()函数中定义

C. C语言程序总是从main()函数开始执行

D. C语言程序中的main()函数必须放在程序的开始部分

3、选出下列标识符中不是合法的标识符的是( )。

A. hot_do

B. cat1

C. _pri

D. 2ab

4、下列描述中不正确的是( )。

A、字符型数组中可能存放字符串。

B、可以对字符型数组进行整体输入、输出。

C、可以对整型数组进行整体输入、输出。

D、 不能在赋值语句中通过赋值运算符“=”对字符型数组进行整体赋值。

5、若已定义:int a[9], *p=a并在以后的语句中未改变p的值,不能表示a[1]地址的表达式为( )。

A. p+1

B. a+1

C. a++

D. ++p

6、设有如下定义: int x=10,y=3,z则语句printf("%d\n",z=(x%y,x/y))的输出结果是( )。

A. 1

B. 0

C. 4

D. 3

7、定义如下变量和数组: int i, x[3][3]={1,2,3,4,5,6,7,8,9}则下面语句for(i=0i<3i++) printf("%d",x[i][2-i])的输出结果是( )

A. 1 5 9

B. 1 4 7

C. 3 5 7

D. 3 6 9

8、读出以下语句的输出结果是( )。

int x=10,y=10

printf(“%d %d\n”,x--,--y)

A. 10 10

B. 9 9

C. 9 10

D. 10 9

9、两次运行下面的程序,如果从键盘上分别输入6和3,则输出结果是( )。

if(x++>5) printf("%d",x)

else printf("%d\n",x - -)

A. 7和5

B. 6和3

C. 7和4

D. 6和4

10、设有如下定义:char *aa[2]={"abcd","ABCD"}则以下说法中正确的是( )。

A)aa数组成元素的值分别是"abcd"和ABCD"

B)aa是指针变量,它指向含有两个数组元素的字符型一维数组

C)aa数组的两个元素分别存放的是含有4个字符的一维字符数组的`首地址

D)aa数组的两个元素中各自存放了字符’a’和’A’的地址

11、以下语句的输出结果是( )。

int a=-1,b=4,k

k=(+ +a<0)&&!(b - -<=0)

printf("%d,%d,%d\n",k,a,b)

A. 1,0,4

B. 1,0,3

C. 0,0,3

D. 0,0,4

12、下列程序的输出结果是( )。

char *p1="abcd", *p2="ABCD", str[50]="xyz"

strcpy(str+2,strcat(p1+2,p2+1))

printf("%s",str)

A. xyabcAB

B. abcABz

C. ABabcz

D. xycdBCD

13、执行下面的程序后,a的值是( )。

#define SQR(X) X*X

main( )

{ int a=10,k=2,m=1

a/=SQR(k+m)/SQR(k+m)

printf("%d\n",a)}

A. 10

B. 1

C. 9

D. 0

14、设A为存放(短)整型的一维数组,如果A的首地址为P,那么A中第i 个元素的地址为( )。

A.P+i*2

B. P+(i-1)*2

C. P+(i-1)

D. P+i

15、下列程序执行后输出的结果是( )。

int d=1

fun (int p)

{ int d=5

d + =p + +

printf("%d,",d)}

main( )

{ int a=3

fun(a)

d + = a + +

printf("%d\n",d)}

A. 8, 4

B. 9, 6

C. 9, 4

D. 8, 5

16、表达式:10!=9的值是( )。

A. true

B. 非零值

C. 0

D. 1

17、若有说明: int i,j=7, *p=&i, 则与i=j等价的语句是( )。

A. i= *p

B. *p=*&j

C. i=&j

D. i=* *p

18、不能把字符串:Hello!赋给数组b的语句是( )。

A. char b[10]={’H’,’e’,’l’,’l’,’o’,’!’}

B. char b[10]b="Hello!"

C. char b[10]strcpy(b,"Hello!")

D.char b[10]="Hello!"

19、在C程序中有如下语句:char *func(int x,int y)它是( )。

A. 对函数func的定义。

B. 对函数func的调用。

C.对函数func的原型说明。

D. 不合法的。

20、以下程序的输出结果是( )。

char str[15]=”hello!”

printf(“%d\n”,strlen(str))

A. 15

B. 14

C. 7

D. 6

参考答案:

1、B 2、C 3、D 4、C 5、C 6、D 7、C 8、D 9、C 10、D

11、D 12、D 13、B 14、B 15、A 16、D 17、B 18、B 19、C 20、D

main()

{ int k, a[10]={1,2,3,4,5}

for(k=1k<3k++) fun(a)

for(k=0k<5k++) printf("%d", a[k])

}

上面程序的输出结果是

A.34756

B.23445

C.35743

D.12345

(40) 请读程序:

#include

#define SUB(X,Y) (X)*Y

main()

{ int a=3, b=4

printf("%d", SUB(a++, b++))

}

上面程序的输出结果是

A.12

B.15

C.16

D.20(41) 请读程序:

#include

main()

{ int mun=0

while(num<=2)

{ num++printf("%d\n",num)}

}

上面程序的输出结果是

A.1

B.1

C.1

D.1

2 2 2

3 3

4

(42) 请读程序:

#include

main()

{ float x,y

scan("%f",&x)

if(x<0.0) y=0.0

else if((x<5.0)&&(x!=2.0))

y=1.0/(x+2.0)

else if (x<10.0) y=1.0/x

else y=10.0

printf("%f\n",y)

}

若运行时从键盘上输入2.0(表示回车),则上面程序的输出结果是

A.0.000000

B.0.250000

C.0.500000

D.1.000000

(43) 请读程序:

#include

main()

{ int x=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=%d\n",a,

B.

}

上面程序的输出结果是

A.a=2, b=1

B.a=1, b=1

C.a=1, b=0

D.a=2, b=2

(44) 若有下面的程序片段:

int a[12]={0}, *p[3], **pp, i

for(i=0i<3i++)

p[i]=&a[i*4]

pp=p

则对数组元素的错误引用是

A.pp[0][1]

B.a[10]

C.p[3][1]

D.*(*(p+2)+2)

(45) 请读程序:

#include

#include

main()

{ float x,y,z

scan("%f%f",&x,&y)

z=x/y

while(1)

{ if(fabs(z)>1.0)

{ x=yy=zz=x/y

}

else break

}

printf("%f\n",y)

}

若运行时从键盘上输入3.6 2.4(表示回车),则输出的结果是

A.1.500000

B.1.600000

C.2.000000

D.2.400000

(46) 请读程序:

#include

f(in b[], int n)

{ int i, r

r=1

for(i=0i<=ni++) r=r*b[i]

return r

}

main()

{ int x, a[]={ 2,3,4,5,6,7,8,9}

x=f(a, 3)

printf("%d\n",x)

}

上面程序的输出结果是

A.720

B.120

C.24

D.6

(47) 请读程序:

#include

#include

void fun( char *s)

{ char a[10]

strcpy( a, "STRING")

s=a

}

main()

{ char *p

fun(p)

x=f(a, 3)

printf("%s\n",p)

}

上面程序的输出结果是(└┘表示空格)

A.STRING└┘└┘└┘└┘

B.STRING

C.STRING└┘└┘└┘

D.不确定的值

(48) 若已建立下面的链表结构,指针p、s分别指向图中所示的结点,则不能将s所指的结点插入到链表末尾的语句组是

A.s->next=NULLp=p->nextp->next=s

B.p=p->nexts->next=p->nextp->next=s

C.p=p->nexts->next=pp->next=s

D.p=(*p).next(*s).next=(*p).next(*p).next=s

(49) 请读程序:

#include

void fun(float *pl, float *p2, float *s)

{ s=( float * )calloc( 1, sizeof(float))

*s=*p1+ *(p2++)

}

main()

{ float a[2]={1.1, 2.2}, b[2]={10.0, 20.0}, *s=a

fun(a, b, s)

printf("%f\n",*s)

}

上面程序的输出结果是

A.11.100000

B.12.100000

C.21.100000

D.1.100000

(50) 请读程序:

#include

#include

void fun( char *w, int m)

{ char s, *p1, *p2

p1=wp2=w+m-1

while (p1{ s=*p1++*p1=*p2--*p2=s}

}

main()

{ char a[]="ABCDEFG"

fun( a, strlen(a))

puts(a)

}

上面程序的输出结果是

A.GFEDCBA

B.AGADAGA

C.AGAAGAG

D.GAGGAGA

二、填空题(每空2分,共40分)

请将每空的正确答案写在答题卡上【1】-【20】序号后的横线上,答在试卷上不得分。

(1) DOS命令分为内部命令与外部命令,XCOPY命令是 【1】 命令

(2) 为了列出当前盘当前目录中所有第三个字符为C的文件名的有关信息,应该用命令 【2】 。

(3) 设当前盘为A盘,当前目录为\X\Y,A盘上的一个文件QR.C在当前目录下的子目录W中。现已将A盘的当前目录改为\D\XY,当前盘改为C盘,如需指定A盘上该文件应写成 【3】 。

(4) 用十六进制给存储器中的字节地址进行编号,其地址编号是从0000到FFFF,则该存储器的容量是【4】KB。

(5) 设有两个八位二进制数00010101与01000111相加,其结果的十进制表示为 【5】 。

(6) 数学式子 写成C语言表达式是 【6】 。

(7) 下面程序的输出结果是 【7】 。

#include

main()

{ static char b[]="Goodbye"

char *chp=&b[7]

while( --chp >=&b[0]) putchar( *chp)

putchar(’\n’)

}

(8) 下面程序的输出结果是 【8】 。

#include

void as( int x, int y, int *cp, int *dp)

{ *cp=x+y

*dp=x-y

}

main()

{ int a=4, b=3, c, d

as( a, b, &c, &d)

printf( ’%d %d\n", c, d)

}

(9) 请读程序:

#include

main( int argc, char *argv[])

{ int i

printf( ’%d\n", argc)

for( i=0i<=argc+1i++) printf( "%s ", argv[i])

printf("\n")

}

若上面的程序编译、连接后生成可执行文件ABC.EXE,则输入以下命令行

abc file1 file2(表示回车)

程序执行后的输出结果是 【9】 。

(10) 条件“20(11) 设二进制数a是00101101,若想通过异或运算a^b使a的高4位取反,低4位不变,则二进制数b应是 【11】 。

(12) 若有以下说明和定义语句,则变量w在内存中所占的字节数是 【12】 。

union aa

{ float x, y

char c[6]

}

struct st { union aa vfloat w[5]double ave} w

(13) 下面程序的输出结果是 【13】 。

#include

#define N 5

fun( char *s, char a, int n)

{ int j

*s=aj=n

while( ereturn j

}

main()

{ char s[N+1]

int k, p

for( k=1k<=Nk++)

s[k]=’A’+k+1

printf( "%d\n", fun(s, ’E’, N))

}(14) 下面程序的输出结果是 【14】 。

#include

void fun( char *a1, char *a2, int n)

{ int k

for( k=0ka2[k]=( a1[k]-’A’-3+26)&+’A’

a2[n]=’\0’

}

main()

{ char s1[5]="ABCD", s2[5]

fun( s1, s2, 4)

puts( s2)

}

(15) 下面的findmax函数返回数组s中最大元素的下标,数组中元素的个数由t传入,请填空。

findmax( int s[], int t)

{ int k, p

for( p=0, k=ppif( s[p]>s[k]) 【15】 。

return k

}

(16) 下面程序的输出结果是 【16】 。

#include

fun( int x)

{ int p

if( x==0||x==1) return(3)

p=x-fun( x-2)

return p

}

main()

{ printf( "%d\n", fun(9))}

(17) 下面程序的输出结果是 【17】 。

#include

funa( int a, int b)

{ return a+b}

funb( int a, int b)

{ return a-b}

sub( int (*t)(), int x, int y)

{ return((*t)( x,y))}

main()

{ int x, (*p)()

p=funa

x=sub(p,9,3)

x+=sub(funb, 8, 3)

printf("%d\n", x)

}

(18) 下面程序的输出结果是 【18】 。

#include

main()

{ char *p[]={ "BOOL", "OPK", "H", "SP"}

int i

for(i=3i>=0i--,i--) printf( "%c", *p[i])

printf("\n")

}

(19) 为了建立如图所示的存储结构(即每个结点含两个域,data是数据域,next是向结点的指针域),请填空。

data next

struct link { char data【19】 } node

(20) 下面的程序用来统计文件中字符的个数,请填空。

#include

main()

{ FILE *fp

long num=0

if(( fp=fopen("fname.dat","r"))==NULL)

{ printf( "Can’t open file! \n")exit(0)}

while 【20】

{ fgetc(fp)num++}

printf("num=%d\n", num)

fclose(fp)

}

参考答案

一`选择题((1)~(40)题每题1分,(41)~(50)题每题2分,共60分)

(1)C (2)A (3)B (4)D (5)D (6)A (7)C (8)B (9)D (10)C

(11)B (12)D (13)A (14)C (15)B (16)A (17)B (18)A (19)C (20)C

(21)D (22)B (23)B (24)A (25)C (26)D (27)D (28)B (29)C (30)A

(31)B (32)B (33)D (34)C (35)A (36)C (37)A (38)B (39)C (40)A

(41)C (42)C (43)A (44)C (45)B (46)B (47)D (48)C (49)D (50)C

二` 填空题(每空2分,共40分)

(第(2)`(3)空允许小写或大小写混合使用,其它空均须与答案一样)

(1) 外部

(2) DIR ?? C*.*

(3) A:\X\Y\W\QR.C

(4) 64

(5) 92

(6) pow(sin(x),2) * (a+b)/(a-b) 或 sit(x) * sit(x) * (a+b)/(a-b)

(7) eybdooG

(8) 7 1

(9) 3 abc.exe file1 file2 (注:两个答案,每个1分)

(10) ((20 (11) 11110000

(12) 34

(13) 3

(14) XYZA

(15) k=p

(16) 7

(17) 17

(18) SO

(19) struct link *next

(20) (!feof(fp))或(feof(fp)==0)