当前位置:首页>计算机二级>考试题型

计算机二级考试试题样卷-C语言程序设计

更新【xīn】:2024-9-21 20:56:40    发布:大【dà】学【xué】生必备网      纠错

全国计算机等级考试二级笔试样卷C语言程序设计

一、选择题((1)~(10)、(21)~(40)每题2分【fèn】,(11)~(20)每题2分,共70分【fèn】)

下列各题【tí】A)、B)、C)、D)四个选项中,只有一个选项是正确【què】的,请将【jiāng】正确【què】选项【xiàng】涂写在【zài】答题卡相应位置【zhì】上,答【dá】在试卷上不得分。

(1)下列选项中不符合良好程序设计风格的是

A) 源程序【xù】要文【wén】档化      B) 数据【jù】说明【míng】的次序要规范化

C) 避免滥【làn】用goto语句【jù】   D) 模块设计要【yào】保证高耦合、高【gāo】内聚

(2)从工程管理角度,软件设计一般分为两步完成,它们是

A) 概要【yào】设计与【yǔ】详细设【shè】计【jì】  B) 数据设计与接口设计

C) 软件结构设计与数据【jù】设计【jì】  D) 过程【chéng】设计与数【shù】据设计【jì】

(3)下列选项中不属于软件生命周期开发阶段任务的是

A)软件【jiàn】测试     B)概要设计 C)软件维护 D)详细设计【jì】

(4)在数据库系统中,用户所见的数据模式为

A) 概【gài】念模式【shì】    B)外模式【shì】  C)内模【mó】式   D)物理模式

(5)数据库设计的四个阶段是:需求分析、概念设计、逻辑设计和

A) 编【biān】码【mǎ】设计    B) 测试阶段    C)运行阶段 D)物理设计

(6)设有如下三个关系表

计算机二级考试试题样卷-C语言程序设计

下列操作中正确的是

A)T=R∩S      B)T=R∪S

C)T=R×S      D)T=R/S

(7)下列叙述中正确的是

A)一个算法的空间复杂度大,则其时间复杂度也必定大

B)一个算法的空间复杂度大,则其时间复杂度必定小

C)一个算法的时间复杂度大,则其空间复杂度必定小

D)上述三种说法都不对

(8)在长度为64的有序【xù】线性表中进行顺序查【chá】找,最坏【huài】情况下【xià】需要比较的次【cì】数【shù】为

A)63   B)64   C)6    D)7

(9)数据库技术的根本目标是要解决数据的

A)存储问题 B)共享问题 C)安全问题 D)保护问题

(10)对下列二叉树

计算机二级考试试题样卷-C语言程序设计

进行中序遍历的结果是

A)ACBDFEG  B)ACBDFGE  C)ABDCGEF  D)FCADBEG

(11)下列叙述中错误的是

A)一个C语言程序只能实现一种算法

B)C程序可以由多个程序文件组成

C)C程序可以由一个或多个函数组成

D)一个C函数可以单独作为一个C程序文件存在

(12)下列叙述中正确的是

A)每个C程序文件中都必须要有一个main()函数

B)在C程序中main()函数的位置是固定的

C)C程序中所有函数之间都可以相互调用,与函数所在位置无关

D)在C程序的函数中不能定义另一个函数

(13)下列定义变量的语句中错误的是

A)int  _int;       B)double  int_;      C)char  For;            D)float  US$;

(14)若变量x、y已【yǐ】正确【què】定【dìng】义并赋值,以下符合C语【yǔ】言语法【fǎ】的表达式是

A)++x,y=x--        B)x+1=y          C)x=x+10=x+y         D)double(x)/10

(15)以下关于逻辑运算符两侧运算对象的叙述中正确的是

A)只能是整数0或1                B)只能是整【zhěng】数0或非0整数【shù】

C)可以是结构体【tǐ】类型【xíng】的数据         D)可【kě】以【yǐ】是任意合法的表达式【shì】

(16)若有定义int  x,y; 并已正确给变量赋值,则以下选【xuǎn】项中【zhōng】与【yǔ】表达式【shì】(x-y)?(x++) : (y++)中【zhōng】的条件表达【dá】式(x-y) 等价的是

A)(x-y>0)      B)(x-y<0) C)(x-y<0||x-y>0)   D)(x-y==0)

(17)有以下程序

main()

{ int  x, y, z;

x=y=1;

z=x++,y++,++y;

printf("%d,%d,%d\n",x,y,z);

}

程序运行后的输出结果是

A)2,3,3            B)2,3,2              C)2,3,1          D)2,2,1

(18)设有定义【yì】:int  a;    float  b;    执行 scanf("%2d%f",&a,&b); 语句【jù】时,若从键盘输【shū】入876  543.0<回车>,a和b的值分别是

A)876和543.000000               B)87和6.000000

C)87和543.000000                D)76和543.000000

(19)有以下程序

main()

{ int  a=0, b=0;

a=10;                     /*  给a赋值

b=20;                         给b赋值【zhí】     */

printf("a+b=%d\n",a+b);   /*  输【shū】出计算结果【guǒ】 */

}

程序运行后的输出结果是

A)a+b=10           B)a+b=30       C)30          D)出错【cuò】

(20)在嵌套使用if语句时,C语言规定else总是

A)和之前与其具有相同缩进位置的if配对

B)和之前与其最近的if配对

C)和之前与其最近的且不带else的if配对

D)和之前的第一个if配对

(21)下列叙述中正确的是

A)break语句只能用于switch语句

B)在switch语句中必须使用default

C)break语句必须与switch语句中的case配对使用

D)在switch语句中,不一定使用break语句

(22)有以下程序

main()

{ int  k=5;

while(--k)  printf("%d",k -= 3);

printf("\n");

}

执行后的输出结果是

A)1           B)2            C)4              D)死【sǐ】循【xún】环

(23)有以下程序

main()

{ int  i;

for(i=1; i<=40; i++)

{ if(i++%5==0)

if(++i%8==0)  printf("%d ",i);

}

printf("\n");

}

执行后的输出结果是

A)5            B)24             C)32             D)40

(24)以下选项中,值为1的表达式是

A)1 –'0'          B)1 - '\0'       C)'1' -0         D)'\0' - '0'

(25)有以下程序

fun(int  x, int  y){ return (x+y); }

main()

{ int  a=1, b=2, c=3, sum;

sum=fun((a++,b++,a+b),c++);

printf("%d\n",sum);

}

执行后的输出结果是

A)6            B)7             C)8            D)9

(26)有以下程序

main()

{  char  s[]="abcde";

s+=2;

printf("%d\n",s[0]);

}

执行后的结果是

A)输出字符a的【de】ASCII码         B)输出【chū】字符【fú】c的ASCII码

C)输出字符【fú】c                    D)程序【xù】出【chū】错

(27)有以下程序

fun(int  x, int  y)

{ static int  m=0, i=2;

i+=m+1;    m=i+x+y;    return m;

}

main()

{ int  j=1, m=1, k;

k=fun(j,m);    printf("%d,",k);

k=fun(j,m);    printf("%d\n",k);

}

执行后的输出结果是

A)5, 5         B)5, 11            C)11, 11       D)11, 5

(28)有以下程序

fun(int  x)

{ int  p;

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

p=x-fun(x-2);

return p;

}

main()

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

执行后的输出结果是

A)7            B)3            C)2            D)0

(29)在16位【wèi】编译系统上【shàng】,若有定【dìng】义【yì】int  a[]={10,20,30}, *p=&a;,当执行【háng】p++;后,下列说法错【cuò】误的是

A)p向高地址移了一【yī】个字节        B)p向【xiàng】高【gāo】地址移了一个存【cún】储【chǔ】单元

C)p向高地址移了【le】两个【gè】字节【jiē】        D)p与a+1等价【jià】

(30)有以下程序

main()

{ int  a=1, b=3, c=5;

int  *p1=&a, *p2=&b, *p=&c;

*p =*p1*(*p2);

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

}

执行后的输出结果是

A)1            B)2            C)3            D)4

(31)若有定义:int w[3][5]; ,则以【yǐ】下不能【néng】正确表示该数组元素的【de】表达式【shì】是

A)*(*w+3)      B)*(w+1)[4]        C)*(*(w+1))        D)*(&w[0][0]+1)

(32)若有以下函数首部

int  fun(double  x[10], int  *n)

则下面针对此函数的函数声明语句中正确的是

A)int  fun(double x, int *n);      B)int  fun(double  , int );

C)int  fun(double *x, int n);      D)int  fun(double *,  int *);

(33)有以下程序

void change(int k[ ]){ k[0]=k[5]; }

main()

{ int  x[10]={1,2,3,4,5,6,7,8,9,10},n=0;

while( n<=4 ) { change( &x[n]) ; n++; }

for(n=0; n<5; n++) printf("%d ",x[n]);

printf("\n");

}

程序运行后输出的结果是

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

(34)有以下程序

main()

{ int  x[3][2]={0}, i;

for(i=0; i<3; i++) scanf("%d",x[i]);

printf("%3d%3d%3d\n",x[0][0],x[0][1],x[1][0]);

}

若运行时输入:2 4 6<回车>,则输出结果为

A)2  0  0      B)2  0  4      C)2  4  0      D)2  4  6

(35)有以下程序

int add( int  a,int  b){ return (a+b);  }

main()

{ int  k, (*f)(), a=5,b=10;

f=add;

}

则以下函数调用语句错误的是

A)k=(*f)(a,b);                 B)k=add(a,b);

C)k= *f(a,b);                      D)k=f(a,b);

(36)有以下程序

#include

main( int  argc, char  *argv[ ])

{ int  i=1,n=0;

while (i

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

}

该程序生成的可执行文件【jiàn】名为:proc.exe。若【ruò】运行时输入命【mìng】令行【háng】:

proc  123  45  67

则程序的输出结果是

A)3            B)5            C)7            D)11

(37)有以下程序

# include

# define    N    5

# define    M    N+1

# define    f(x)   (x*M)

main()

{ int  i1, i2;

i1 = f(2) ;

i2 = f(1+1) ;

printf("%d  %d\n", i1, i2);

}

程序的运行结果是

A)12  12       B)11  7        C)11  11       D)12  7

(38)有以下结构体说明、变量定义和赋值语句

struct STD

{ char  name[10];

int  age;

char  sex;

} s[5],*ps;

ps=&s[0];

则以下scanf函数调用语句中错误引用结构体变量成员的是

A)scanf("%s",s[0].name);          B)scanf("%d",&s[0].age);

C)scanf("%c",&(ps->sex));         D)scanf("%d",ps->age);

(39)若有以下定义和语句

union data

{  int  i;   char  c;   float  f; } x;

int  y;

则以下语句正确的是

A)x=10.5;      B)x.c=101;     C)y=x;         D)printf("%d\n",x);

(40)有以下程序

#include

main()

{ FILE  *fp;    int  i;

char  ch[]="abcd",t;

fp=fopen("abc.dat","wb+");

for(i=0; i<4; i++) fwrite(&ch[i],1,1,fp);

fseek(fp,-2L,SEEK_END);

fread(&t,1,1,fp);

fclose(fp);

printf("%c\n",t);

}

程序执行后的输出结果是

A)d            B)c            C)b            D)a

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

请将每一个空【kōng】的【de】正确答【dá】案写在答题卡【1】至【15】序号的横线上,答【dá】在【zài】试卷【juàn】上【shàng】不【bú】得分。

(1)下列软件系统结构图

的宽度为  【1】  。

(2)  【2】  的【de】任【rèn】务是诊断和改正程序中的错【cuò】误。

(3)一【yī】个关系表的行称为   【3】   。

(4)按“先进【jìn】后出【chū】”原则【zé】组织数据【jù】的数据结构是  【4】    。

(5)数据结【jié】构分为线性结【jié】构和非线性结【jié】构,带链的队列属于  【5】   。

(6)设有【yǒu】定【dìng】义:float  x=123.4567;,则执行以下语句【jù】后的输出结果是 【6】 。

printf("%f\n",(int)(x*100+0.5)/100.0);

(7)以下程序运行后【hòu】的输出结【jié】果是 【7】 。

main()

{ int  m=011,n=11;

printf("%d  %d\n",++m, n++);

}

(8)以下程序运【yùn】行后的输出结【jié】果【guǒ】是 【8】 。

main()

{ int  x,a=1,b=2,c=3,d=4;

x=(a   x=(x   x=(d>x) ? x : d;

printf("%d\n",x);

}

(9)有【yǒu】以下【xià】程序,若运行时从【cóng】键盘输入:18,11<回车>,则程序的输出【chū】结果是 【9】 。

main()

{  int  a,b;

printf("Enter a,b:");   scanf("%d,%d",&a,&b);

while(a!=b)

{  while(a>b) a -= b;

while(b>a) b -= a;

}

printf("%3d%3d\n",a,b);

}

(10)以下程序的功能是:将【jiāng】输入的正整数按逆序输【shū】出。例【lì】如【rú】:若输入135则输出531。请【qǐng】填空。

#include

main()

{ int  n,s;

printf("Enter a number : ");   scanf("%d",&n);

printf("Output:  ");

do

{  s=n%10;  printf("%d",s);  【10】 ;  }

while(n!=0);

printf("\n");

}

(11)以【yǐ】下程序中,函数fun的功能【néng】是计算【suàn】x2-2x+6,主函数中将调【diào】用fun函【hán】数计算:

y1=(x+8)9-21 (x+8)+6

y2=sin2(x)-2sin(x)+6

请填空。

#include   "math.h"

double fun(double  x){ return (x*x-2*x+6); }

main()

{ double  x,y1,y2;

printf("Enter x:");    scanf("%lf",&x);

y1=fun( 【11】 );

y2=fun( 【12】 );

printf("y1=%lf,y2=%lf\n",y1,y2);

}

(12)下面程序的功能是:将【jiāng】N行N列二维数组中每一行【háng】的元素进行排序,第0行从小到大排序【xù】,第1行从大到【dào】小【xiǎo】排序【xù】,第【dì】2行【háng】从小到大排序【xù】,第【dì】3行从大【dà】到小排【pái】序,例如:

#define    N    4

void sort(int  a[][N])

{ int  i, j, k, t;

for (i=0; i

for (j=0; j

for (k=  【13】 ; k

/*判断行下标是否为偶数来确定按升序或降序来排序*/

if ( 【14】 ? a[i][j]a[i][k])

{  t = a[i][j];

a[i][j]=a[i][k];

a[i][k] = t;

}

}

void outarr(int  a[N][N])

{    ……    }

main()

{ int  aa[N][N]={{2,3,4,1},{8,6,5,7},{11,12,10,9},{15,14,16,13}};

outarr(aa); /*以矩阵的形式输出二维数组*/

sort(aa);

outarr(aa);

}

(13)下面程序的【de】运行结【jié】果是:【15】  。

#include

int f(int  a[],int  n)

{ if(n>1)

return a[0] + f(a+1, n-1);

else

return a[0];

}

main()

{ int  aa[10]={1,2,3,4,5,6,7,8,9,10}, s;

s = f(aa+2,4);    printf("%d\n", s);

}