`

2005 年4 月全国计算机等级考试C 语言笔试试卷

阅读更多

 

(考试时间 120 分钟,满分100 分)

一、选择题((1)-(10)每小题2 分,(11)-(50)每小题1 分,共60 分)

(1)数据的存储结构是指( )。

A)存储在外存中的数据

B)数据所占的存储空间量

C)数据在计算机中的顺序存储方式

D)数据的逻辑结构在计算机中的表示

(2)下列关于栈的描述中错误的是( )。

A)栈是先进后出的线性表

B)栈只能顺序存储

C)栈具有记忆作用

D)对栈的插入与删除操作中,不需要改变栈底指针

(3)对于长度为n 的线性表,在最坏情况下,下列各排序法所对应的比较次数中正确的是

( )。

A)冒泡排序n/2      B)冒泡排序为n

C)快速排序为n      D)快速排序为n(n-1)/2

(4)对于长度为n 的线性表进行顺序查找,在最坏情况下所需要的比较次数为( )。

A)log2n     B)n/2     C)n      D)n+1

(5)下列对于线性链表的描述中正确的是( )。

A)存储空间不一定是连续,且各元素的存储顺序是任意的

B)存储空间不一定是连续,且前件元素一定存储在后件元素的前面

C)存储空间必须连续,且前件元素一定存储在后件元素的前面

D)存储空间必须连续,且各元素的存储顺序是任意的

(6)下列对于软件测试的描述中正确的是( )。

A)软件测试的目的是证明程序是否正确

B)软件测试的目的是使程序运行结果正确

C)软件测试的目的是尽可能多地发现程序中的错误

D)软件测试的目的是使程序符合结构化原则

(7)为了使模块尽可能独立,要求( )。

A)模块的内聚程度要尽量高,且各模块间的耦合程度要尽量强

B)模块的内聚程度要尽量高,且各模块间的耦合程度要尽量弱

C)模块的内聚程度要尽量低,且各模块间的耦合程度要尽量弱

二级C 语言程序设计试卷第 2 页(共13 页)

D)模块的内聚程度要尽量低,且各模块间的耦合程度要尽量强

(8)下列描述中正确的是( )。

A)程序就是软件

B)软件开发不受计算机系统的限制

C)软件既是逻辑实体,又是物理实体

D)软件是程序、数据与相关文档的集合

(9)数据独立性是数据库技术的重要特点之一。所谓数据独立性是指( )。

A)数据与程序独立存放

B)不同的数据被存放在不同的文件中

C)不同的数据只能被对应的应用程序所使用

D)以上三种说法都不对

(10)用树形结构表示实体之间联系的模型是( )。

A)关系模型     B)网状模型    C)层次模型    D)以上三个都是

(11)算法具有5 个特性,下列选项中不属于算法特性的是( )。

A)有穷性    B)简洁性    C)可行性    D)确定性

(12)下列选项中可作为C 语言合法常量的是( )。

A)-80    B)-080    C)-8e1.0     D)-80.0e

(13)下列叙述中正确的是( )。

A)用C 程序实现的算法必须要有输入和输出操作

B)用C 程序实现的算法可以没有输出但必须要有输入

C)用C 程序实现的算法可以没有输入但必须要有输出

D)用C 程序实现的算法可以既没有输入也没有输出

(14)下列不能定义的用户标识符是( )。

A)Main    B)_0    C)_int     D)sizeof

(15)下列选项中,不能作为合法常量的是( )。

A)1.234e04    B)1.234e0.4   C)1.234e+4    D)1.234e0

(16)数字字符0 的ASCII 值为48,运行下列程序的输出结果是( )。

main( )

{ char a='1',b='2';

printf("%c,", b+ +);

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

}

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

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

main( )

{ int m=12, n=34;

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

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

}

A)12353514    B)12353513   C)12343514    D)12343513

(18)有定义语句:int b; char c[10];,则正确的输入语句是( )。

A)scanf("%d%s",&b,&c);    B)scanf("%d%s",&b,c);

C)scanf("%d%s",b,c);       D)scanf("%d%s",b,&c);

(19)有下列程序:

main( )

{ int m,n,p;

scanf("m=%dn=%dp=%d",&m,&n,&p);

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

}

若想从键盘上输入数据,使变量m 中的值为123,n 中的值为456,p 中的值为789,

则正确的输入是( )。

A)m=123 n=456 p=789        B)m=123 n=456 p=789

C)m=123,n=456,p=789        D)123 456 789

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

main( )

{ int a,b,d=25;

a= d/10%9;

b=a&&(-1);

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

A)6,1     B)2,1     C)6,0     D)2,0

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

main( )

{ int i=1,j=2,k=3;

if(i+ + = =1&&(+ +j= =3‖k+ + = =3)) printf("%d %d %d\n",i,j,k);

}

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

(22)若整型变量a、b、c、d 中的值依次为:1、4、3、2。则条件表达式a<b? a∶c<d? c∶

d 的值是( )。

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

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

main( )

{ int p[8]={11,12,13,14,15,16,17,18},i=0,j=0;

while(i+ +<7)

if(p[i]%2) j+ =p[i];

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

}

A)42     B)45    C)56     D)60

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

main( )

{ char a[7]="a0\0a0\ 0"; int i,j;

i=sizeof(a);

j=strlen(a);

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

}

A)2 2    B)7 6     C)7 2    D)6 2

(25)下列能正确定义一维数组的选项是( )。

A)int a[5]={0,1,2,3,4,5};     B)char a[ ]={0,1,2,3,4,5};

C)char a={'A', 'B', 'C'};      D)int a[5]="0123";

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

int f1(int x,int y){return x>y?x∶y;}

int f2(int x,int y){return x>y?y∶x;}

main( )

{ int a=4,b=3,c=5,d=2,e,f,g;

e=f2(f1(a,b),f1(c,d));

f=f1(f2(a,b),f2(c,d));

g=a+b+c+d-e-f;

printf("%d,%d,%d\n",e,f,g);

}

A)4,3,7     B)3,4,7     C)5,2,7     D)2,5,7

(27)已有定义:char a[ ]="xyz",b[ ]={'x', 'y', 'z'};,下列叙述中正确的是( )。

A)数组a 和b 的长度相同          B)a 数组长度小于b 数组长度

C)a 数组长度大于b 数组长度       D)上述说法都不对

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

void f(int *x, int *y)

{ int t;

t=*x,*x=*y;*y=t;

}

main( )

{ int a[8]={1,2,3,4,5,6,7,8},i,*p,*q;

p=a;q=&a[7];

while(p<q)

{ f(p,q); p+ +; q--;}

for (i=0;i<8;i+) printf("%d,",a[i]);

}

A)8,2,3,4,5,6,7,1     B)5,6,7,8,1,2,3,4

C)1,2,3,4,5,6,7,8     D)8,7,6,5,4,3,2,1

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

main( )

{ int a[3][3],*p,i; p=&a[0][0];

for(i=0;i<9;i+ +) p[i]=i;

for(i=0;i<3;i+ +) printf("%d",a[1][i]); }

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

(30)下列叙述中错误的是( )。

A)对于double 类型数组,不可以直接用数组名对数组进行整体输入或输出

B)数组名代表的是数组所占存储区的首地址,其值不可改变

C)在程序执行中,数组元素的下标超出所定义的下标范围时,系统将给出“下标越

界”的出错信息

D)可以通过赋初值的方式确定数组元素的个数

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

#define N 20

fun(int a[ ],int n,int m)

{ int i,j;

for(i=m;i>n;i--)a[i+1]=a[i]

}

main( )

{ int i,a[N]={1,2,3,4,5,6,7,8,9,10};

fun(a,2,9);

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

}

A)10234    B)12344    C)12334    D)12234

(32)运行下列程序时,输入1 2 3<CR>的输出结果为( )。

main( )

{ int a[3][2]={0},(*ptr)[2],i,j;

for(i=0;i<2;i+ +)

{ ptr=a+i; scanf("%d",ptr); ptr+ +;

}

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

{ for(j=0;j<2;j+ +)

printf("%2d",a[i][j]);

printf("\n");

}

}

        


               
 
         

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

prt(int *m,int n)

{ int i;

for(i=0;i<n;i+ +)m[i]+ +; }

main( )

{ int a[ ]={1,2,3,4,5},i;

prt(a,5)

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

}

A)1,2,3,4,5      B)2,3,4,5,6     C)3,4,5,6,7      D)2,3,4,5,1

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

main( )

{ int a[ ]={1,2,3,4,5,6,7,8,9,0},*p;

for(p=a;p<a+10;p+ +)

printf("%d,",*p);

}

A)1,2,3,4,5,6,7,8,9,0,     B)2,3,4,5,6,7,8,9,10,1,

C)0,1,2,3,4,5,6,7,8,9,     D)1,1,1,1,1,1,1,1,1,1,

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

#define P 3

void F(int x){ return(P*x*x); }

main( )

{ printf("%d\n",F(3+5)); }

A)192     B)29     C)25      D)编译出错

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

main( )

{ int c=35; printf("%d\n",c&c);}

A)0      B)70     C)35     D)1

(37)下列叙述中正确的是( )。

A)预处理命令行必须位于源文件的开头

B)在源文件的一行上可以有多条预处理命令

C)宏名必须用大写字母表示

D)宏替换不占用程序的运行时间

(38)若有下列说明和定义。

union dt

{ int a; char b; double c;}data;

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

A)data 的每个成员起始地址都相同

B)变量data 所占内存字节数与成员c 所占字节数相等

C)程序段:data.a=5;printf("%f\n",data.c);输出结果为5.000000

D)data 可以作为函数的实参

(39)下列语句或语句组中,能正确进行字符串赋值的是( )。

A)char *sp; *sp="right!";      B)char s[10]; s="right!";

C)char s[10]; *s="right";      D)char *sp="right!";

(40)设有如下说明:

typedef struct ST

{ long a; int b; char c[2]; } NEW;

则下列叙述中正确的是( )。

A)以上的说明形式非法            B)ST 是一个结构体类型

C)NEW 是一个结构体类型名       D)NEW 是一个结构体变量

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

main( )

{ int a=1,b;

for(b=1;b<=10;b+ +)

{ if(a>=8) break;

if(a%2= =1)

{a+ =5; continue;}

a=3;

}

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

}

A)3    B)4   C)5    D)6

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

main( )

{ char s[ ]="159",*p;

p=s;

printf("%c",*p+ +);

printf("%c",*p+ +);

}

A)15    B)16    C)12    D)59

(43)有下列函数:

fun(char *a,char *b)

{ while(*a! ='\0')&&(*b! = '\0')&&(*a= =*b)}

{ a+ +; b+ +;}

return(*a-*b);

}

该函数的功能是( )。

A)计算a 和b 所指字符串的长度之差

B)将b 所指字符串复制到a 所指字符串中

C)将b 所指字符串连接到a 所指字符串后面

D)比较a 和b 所指字符串的大小

(44)有下列程序:

main( )

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

for(i=0;i<4;i+ +)

{ for(j=0;j<i;j+ +)

printf("%4c",' ');

for(j=__;j<4;j+ +)

printf("%4d",num[i][j]);

printf("\n");

}

}

若要按下列形式输出数组右上半三角。

1  2  3   4

6  7   8

11  12

16

则在程序下划线处应填入的是( )。

A)i-1    B)I   C)i+1    D)4-i

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

point(char*p){ p+ =3; }

main( )

{ char b[4]={'a','b','c','d'},*p=b;

point(p); printf("%c\n",*p);

}

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

(46)程序中若有下列说明和定义语句:

char fun(char *);

main( )

{ char *s="one",a[5]={0},(*f1)( )=fun,ch;

}

下列选项中对fun()函数的正确调用语句是( )。

A)(*fl)(a);    B)*fl(*s);     C)fun(&a);    D)ch=*fl(s);

(47)有下列结构体说明和变量定义,如图所示,指针p、q、r 分别指向此链表中的三个连续结点。



 

struct node

{ int data;

struct node *next;

}*p,*q,*r;

现要将q 所指结点从链表中删除,同时要保持链表的连续,下列不能完成指定操作的

语句是( )。

A)p->next=q->next; B)p-next=p->next->next;

C)p->next=r; D)p=q->enxt;

(48)下列对结构体类型变量td 的定义中,错误的是( )。

A)typedef struct aa      B)struct aa

{ int n;                 { int n;

float m;                float m;

}AA;                   }td;

AA td;                  struct aa td;

C)struct               D)struct

{ int n;                 { int n;

float m;                float m;

}aa;                    }td;

struct aa td;

(49)下列与函数fseek(fp,0L,SEEK_SET)有相同作用的是( )。

A)feof(fp)     B)ftell(fp)      C)fgetc(fp)    D)rewind(fp)

(50)有下列程序:

#include <stdio.h>

void WriteStr(char *fn,char *str)

{ FILE *fp;

fp=fopen(fn,"w"); fputs(str,fp); fclose(fp);

}

main( )

{ WriteStr("t1.dat","start");

WriteStr("t1.dat","end");

}

程序运行后,文件t1.dat 中的内容是( )。

A)start    B)end     C)startend    D)endrt

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

(1)某二叉树中度为2 的结点有18 个,则该二叉树中有 【1】  个叶子结点。

(2)在面向对象方法中,类的实例称为 【2】  。

(3)诊断和改正程序中错误的工作通常称为 【3】  。

(4)在关系数据库中,把数据表示成二维表,每一个二维表称为【4】 。

(5)问题处理方案正确而完整的描述称为 【5】  。

(6)下列程序运行时若从键盘输入:10 20 30<CR>。输出结果是 【6】  。

#include <stdio.h>

main( )

{ int i=0, j=0, k=0;

scanf("%d%*d%d",&i,&j,&k); printf("%d%d%d\n",i,j,k);

}

(7)下列程序运行后的输出结果是 【7】  。

#define S(x) 4*x*x+1

main( )

{ int i=6, j=8;

printf("%d\n",S(i+j)); }

(8)下列程序运行后的输出结果是 【8】  。

main( )

{ int a=3,b=4,c=5,t=99;

if(b<a&&a<c)t=a;a=c;c=t;

if(a<c&&b<c)t=b,b=a,a=t;

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

(9)下列程序运行后的输出结果是 【9】  。

main( )

{ int a, b,c;

a=10; b=20; c=(a%b<1)‖(a/b>1);

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

}

(10)下列程序运行后的输出结果是【10】

main( )

{ char c1,c2;

for(c1='0',c2='9';c1<c2;c1+ +,c2--) printf("%c%c",c1,c2);

printf("\n");

}

(11)已知字符A 的ASCII 代码值为65,下列程序运行时若从键盘输入:B33<CR>。则输

出结果是 【11】

#include <stdio.h>

main( )

{ char a,b;

a=getchar( );scanf("%d", &b);

a=a-'A'+'0'; b=b*2;

printf("%c %c\n",a,b);

}

(12)下列程序中,fun()函数的功能是求3 行4 列二维数组每行元素中的最大值。请填空。

void fun(int, int, int(*)[4],int*);

main( )

{ int a[3][4]={{12,41,36,28},{19,33,15,27},{3,27,19,1}},b[3],i;

fun(3,4,a,b);

for(i=0;i<3;i+)printf("%4d",b[i]);

printf("\n"); }

void fun(int m, int n, int ar[ ][4], int *br)

{ int i, j, x;

for(i=0;i<m;i+ +)

{ x=ar[i][0];

for(j=0;j<n;j+ +)

if(x<ar[i][j]) x=ar[i][j];

【12】 =x;

}

}

(13)下列程序运行后的输出结果是【13】

void swap(int x,int y)

{ int t;

t=x;x=y;y=t;printf("%d %d ",x,y); }

main( )

{ int a=3,b=4;

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

}

(14)下列程序运行后的结果是【14】  。

#include <string.h>

void fun(char *s, int p, int k)

{ int i;

for(i=p;i<k-1;i+ +) s[i]=s[i+2]; }

main( )

{ char s[ ]="abcdefg";

fun(s,3,strlen(s)); puts(s);

}

(15)下列程序运行后的输出结果是 【15】  。

#include <string.h>

main( )

{ char ch[ ]="abc",x[3][4]; int i;

for(i=0;i<3;i+ +) strcpy(x[i],ch);

for(i=0;i<3;i+ +) printf("%s",&x[i][i]);

printf("\n");

}

(16)下列程序运行后的输出结果是  【16】  。

fun(int a)

{ int b=0; static int c=3;

b+ +; c+ +;

return(a+b+c);

}

main( )

{ int i, a=5;

for(i=0;i<3;i+ +)printf("%d%d",i,fun(a));

printf("\n");

}

(17)下列程序运行后的输出结果是 【17】  。

stuct NODE

{ int k;

struct NODE *link;};

main( )

{ struct NODE m[5],*p=m,*q=m+4;

int i=0;

while(p! =q)

{ p->k=+ +i; p+ +;

q->k=i+ +; q--;

}

q->k=i;

for(i=0;i<5;i+ +) printf("%d",m[i].k);

printf("\n");

}

(18)下列程序中huiwen()函数的功能是检查一个字符串是否是回文,当字符串是回文时,

函数返回字符串:yes!,否则函数返回字符串:no!,并在主函数中输出。所谓回文即

正向与反向的拼写都一样,例如:adgda。请填空。

#include <string.h>

char*huiwen(char *str)

{ char *p1,*p2; int i,t=0;

p1=str; p2= 【18】 ;

for(i=0);i<=strlen(str)/2;i+ +)

if(*p1+ +! =*p2--){t=1;break;}

if( 【19】  )

return("yes!");

else

return("no!");

}

main( )

{ char str[50];

printf("Input:"); scanf("%s",str);

printf("%s\n", 【20】  );

}

  • 大小: 4.1 KB
  • 大小: 2.8 KB
  • 大小: 2.2 KB
分享到:
评论

相关推荐

    2005年9月全国计算机等级考试四级笔试试卷

    【标题】"2005年9月全国计算机等级考试四级笔试试卷"涉及的知识点主要涵盖计算机系统、网络技术、数据库管理、软件工程、数据结构与算法等多个方面。全国计算机等级考试四级是对考生在计算机专业领域综合能力的评估...

    2011年9月全国计算机等级考试二级笔试试卷C语言程序设计

    从给定的文件信息中,我们可以提取到一系列与计算机科学,特别是C语言程序设计相关的知识点。下面是对这些知识点的详细解析: ### 1. 栈的特性与操作 - **知识点**:栈是一种先进后出(Last In First Out, LIFO)...

    2012年3月全国计算机等级考试二级C语言笔试试卷与答案

    综上所述,这份2012年3月全国计算机等级考试二级C语言笔试试卷涵盖了广泛的知识点,从基础的数据结构和算法理解,到数据库和软件工程的基本原则,再到具体的C语言编程技巧和概念,全面考察了考生的综合能力和专业...

    年9月全国计算机等级考试C语言笔试试卷.doc

    【全国计算机等级考试C语言笔试知识点】 全国计算机等级考试C语言笔试主要考察考生对C语言基础知识、编程逻辑、数据结构和算法设计的理解。以下是一些关键知识点的详细说明: 1. **算法与程序的关系**: - 算法是...

    全国计算机等级考试二级笔试考前模拟试卷

    在"全国计算机等级考试二级笔试考前模拟试卷"中,考生需要对这些知识点有深入的理解和熟练的应用。"二级C考前试卷.doc"很可能是包含这些知识点的模拟试题,考生可以通过做题来检验自己的学习成果。而"二级C考前答案....

    2006年9月计算机等级考试二级 JAVA笔试真题及答案

    Java是面向对象的编程语言,二级计算机等级考试中的Java笔试主要考察以下几个核心领域: 1. **基础语法**:这包括变量、数据类型、运算符、控制结构(如if语句、for循环、while循环)以及方法的定义与调用。例如,...

    2005年4月全国计算机等级考试二级VB笔试试卷.doc

    全国计算机等级考试二级VB笔试主要考察考生对计算机基础知识和VB编程语言的理解与应用能力。这份2005年4月的试卷涵盖了多个方面的知识点,包括数据结构、算法、软件工程、数据库理论以及VB编程的基本概念和事件处理...

    2003年4月全国计算机等级考试二级C语言笔试试题

    全国计算机等级考试二级C语言笔试主要考察考生对计算机基础知识和C语言编程能力的理解与应用。这部分试题涵盖了计算机系统基础、操作系统使用、DOS命令、文件管理、C语言基本概念、程序结构以及数据类型等多个方面。...

    2006年9月全国计算机等级考试二级VB笔试真题及答案.doc

    全国计算机等级考试二级...以上是对2006年9月全国计算机等级考试二级VB笔试真题的部分解析,这些知识点涵盖了编程基础、数据库理论、数据结构和VB语言的基本概念,对理解和掌握VB编程以及相关软件工程知识有很大帮助。

    2002年4月全国计算机等级考试二级C语言笔试试题及答案

    全国计算机等级考试二级C语言是针对C编程语言的资格认证,主要考察考生对C语言的基础知识、编程能力和问题解决能力。以下是对试卷中部分题目涉及的知识点的详细解释: 1. **C语言表达式计算**: - `C=a/b+0.4`:在...

    2006年4月全国计算机等级考试二级C语言笔试试题(含参考答案).pdf

    标题中提到的“2006年4月全国计算机等级考试二级C语言笔试试题(含参考答案)”实际上是一个考试文件,它可能包含了一次具体的计算机等级考试中的C语言科目试卷和对应的答案。这类考试是面向全国范围的,目的是评估和...

    2004年4月全国计算机等级考试二级C笔试试卷

    这篇2004年4月全国计算机等级考试二级C笔试试卷涵盖了计算机基础知识和C语言程序设计的相关知识点。让我们逐一解析这些题目中的关键概念: 1. **存储单位**:第1题讲述了1MB等于1024×1024字节,这是计算机存储单位...

    2009年9月全国计算机等级考试二级C笔试试题与答案

    通过对2009年9月全国计算机等级考试二级C笔试试题.doc文档的学习,考生可以回顾和巩固以上提到的知识点,了解当年考试的难度和出题趋势,为未来的备考提供参考。同时,考生应注重实践操作,通过编写程序来提升自己的...

    全国计算机等级考试c语言真题集

    全国计算机等级考试C语言真题集是一份宝贵的复习资料,主要针对希望参加此类考试的考生。这份资源包含了历年来的考试真题,可以帮助考生熟悉考试格式、题型和难度,同时提供了一个检验自身学习成果的平台。C语言是...

    2008年4月全国计算机等级考试二级笔试试卷及答案

    从给定的文件标题、描述、部分内容来看,这是一份2008年4月全国计算机等级考试二级的笔试题目及答案。此类考试通常旨在测试考生对于计算机基础理论、编程语言、数据结构以及数据库等领域的理解和掌握程度。下面将...

    2001年4月全国计算机等级考试二级C笔试试卷及答案

    【知识点详解】 1. 计算机存储器的组成:计算机的存储器分为内...以上知识点涵盖了计算机存储器结构、计算机硬件、操作系统、DOS命令、C语言编程等多个方面,是2001年全国计算机等级考试二级C语言笔试中的核心内容。

Global site tag (gtag.js) - Google Analytics