2005年9月全国计算机等级考试二级C++笔试试题及答案

 我来答
间心水D
2023-02-20 · TA获得超过264个赞
知道小有建树答主
回答量:810
采纳率:96%
帮助的人:82.6万
展开全部
无 为大家收集整理了《2005年9月全国计算机等级考试二级C++笔试试题及答案》供大家参考,希望对大家有所帮助!!!

一、选择题((1)-(10)每小题2分,(11)-(50)每小题1分,共60分)
下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的。请将正确选项真涂在答题卡相应位置上,答在试卷上不得分。
(1)数据的存储结构是指 D
 A)存储在外存中的数据
 B)数据所占的存储空间量
 C)数据在计算机中的顺序存储方式
 D)数据的逻辑结构中计算机中的表示

(2)下列关于栈的描述中错误的是 B
 A)栈是先进后出的线性表
 B)栈只能顺序存储
 C)栈具有记忆作用
 D)对栈的插入与删除操作中,不需要改变栈底指针

(3)对于长度为n的线性表,在最坏情况下,下列各排序法所对应的比较次数中正确的是 D
 A)冒泡排序为n/2
 B)冒泡排序为n
 C)快速排序为n
 D)快速排序为n(n-1)/2

(4)对长度为n的线性表进行顺序查找,在最坏情况下所需要的比较次数为 C
 A)log2n
 B) n/2
 C) n
 D) n+1

(5)下列对于线性链表的描述中正确的是 A
 A)存储空间不一定是连续,且各元素的存储顺序是任意的
 B)存储空间不一定是连续,且前件元素一定存储在后件元素的前面
 C)存储空间必须连续,且前件元素一定存储在后件元素的前面
 D)存储空间必须连续,且各元素的存储顺序是任意的

(6)下列对于软件的描述中正确的是 C
 A)软件测试的目的是证明程序是否正确
 B)软件测试的目的是使程序运行结果正确
 C)软件测试的目的是尽可能多地发现程序中的错误
 D)软件测试的目的是使程序符合结构化原则

(7)为了使模块尽可能独立,要求 B
 A)模块的内聚程序要尽量高,且各模块间的耦合程序要尽量强
 B)模块的内聚程序要尽量高,且各模块间的耦合程序要尽量弱
 C)模块的内聚程序要尽量低,且各模块间的耦合程序要尽量弱
 D)模块的内聚程序要尽量低,且各模块间的耦合程序要尽量强

(8)下列描述中正确的是 D
 A)程序就是软件
 B)软件开发不受计算机系统的限制
 C)软件既是逻辑实体,又是物理实体
 D)软件是程序、数据与相关文档的集合

(9)数据独立性是数据库技术的重要特点之一。所谓数据独立性是指 D
 A)数据与程序独立存放
 B)不同的数据被存放在不同的文件中
 C)不同的数据只能被对应的应用程序所使用
 D)以上三种说法都不对

(10)用树形结构表示实体之间联系的模型是 C
 A)关系模型
 B)网状模型
 C)层次模型
 D)以上三个都是
(11)算法具有五个特性,以下选项中不属于算法特性的是 B
 A)有穷性
 B)简洁性
 C)可行性
 D)确定性

(12)以下选项中可作为C语言合法常量的是 A
 A)-80.
 B)-080
 C)-8e1.0
 D)-80.0e

(13)以下叙述中正确的是 C
 A)用C程序实现的算法必须要有输入和输出操作
 B)用C程序实现的算法可以没有输出但必须要有输入
 C)用C程序实现的算法可以没有输入但必须要有输出
 D)用C程序实现的算法可以既没有输入也没有输出

(14)以下不能定义为用户标识符的是 D
 A)Main
 B)_0
 C)_int
 D)sizeof

(15)以下选项中,不能作为合法常量的是 B
 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);
}
程序运行后的输出结果是 C
 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
 A)12353514
 B)12353513
 C)12343514
 D)12343513

(18)有定义语句:int b;char c[10]; ,则正确的输入语句是 B
 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
 A)m=123n=456p=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);
}
程序运行后的输出结果是 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);
}
程序运行后的输出结果是 D
 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 
 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);
}
程序运行后的输出结果是 B
 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);
}
程序运行后的输出结果是 C
 A)2 2
 B)7 6
 C)7 2
 D)6 2

(25)以下能正确定义一维数组的选项是 B
 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
 A)4,3,7
 B)3,4,7
 C)5,2,7
 D)2,5,7

(27)已有定义:char a[]="xyz",b[]={’x’,’y’,’z’};,以下叙述中正确的是 C
 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 {
f(p,q);
p++;
q--;
}
for(i=0;i<8;i++)
printf("%d,",a[i]);
}
程序运行后的输出结果是 D
 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]);
}
程序运行后的输出结果是 D
 A)0 1 2
 B)1 2 3
 C)2 3 4
 D)3 4 5

(30)以下叙述中错误的是 C
 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]);
}
程序运行后的输出结果是 C
 A)10234
 B)12344
 C)12334
 D)12234

(32)有以下程序
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("-",a[i][j]);
printf("\n");
}
}
若运行时输入:1 2 3回车>,则输出结果为 B
 A)产生错误信息
 B)1 0
  2 0
  0 0
 C)1 2
  3 0
  0 0
 D)1 0
  2 0
  3 0

(33)有以下程序
prt(int *m,int n)
{
int i;
for(i=0;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]);
}
程序运行后的输出结果是: B
 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 printf("%d,",*p);
}
程序运行后的输出结果是 A
 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
#define F(int x) { return (P*x*x);}
main()
{
printf("%d\n",F(3+5));
}
程序运行后的输出结果是 D
 A)192
 B)29
 C)25
 D)编译出错
(36)有以下程序
main()
{
int c=35; printf("%d\n",c&c);
}
程序运行后的输出结果是 C
 A) 0
 B) 70
 C) 35
 D) 1

(37)以下叙述中正确的是 D
 A)预处理命令行必须位于源文件的开头
 B)在源文件的一行上可以有多条预处理命令
 C)宏名必须用大写字母表示
 D)宏替换不占用程序的运行时间

(38)若有以下说明和定义
union dt
{
int a; char b; double c;
}data;
以下叙述中错误的是 C
 A)data的每个成员起始地址都相同
 B)变量data所占内存字节数与成员c所占字节数相等
 C)程序段:data.a=5;printf("%f\n",data.c);输出结果为5.000000
 D)data可以作为函数的实参

(39)以下语句或语句组中,能正确进行字符串赋值的是 D
 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;
则下面叙述中正确的是 C
 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);
}
程序运行后的输出结果是 B
 A)3
 B)4
 C)5
 D)6

(42)有以下程序
main()
{
char s[]="159",*p;
p=s;
printf("%c",*p++);
printf("%c",*p++);
}
程序运行后的输出结果是 A
 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);
}
该函数的功能是 D
 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=1;j<=i;j++) printf("%c",’ ’);
for(j= j<4;j++) printf("M",num[i][j]);
printf("\n");
}
}
若要按以下形式输出数组右上半三角
1 2 3 4
6 7 8
11 12
16
则在程序下划线处应填入的是 B
 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)a
 B)b
 C)c
 D)d

(46)程序中若有如下的说明和定义语句
char fun(char *);
main()
{
char *s="one",a[5]={0},(*f1)()=fun,ch;
……
}
以下选项中对函数fun的正确调用语句是 A
 A)(*f1)(a);
 B)*f1(*s);
 C)fun(&a);
 D)ch=*f1(s)

(47)有以下结构体说明和变量定义,如图所示,指针pqr分别指向此链表中三个连续结点。
struct node
{
int data;
struct node *next;
} *p,*q,*r;
现要将q所指结点从链表中删除,同时保持链表的连续,以下不能完成指定操作的语句是 D
 A)p->next=q->next;
 B)p->next=p->next->next;
 C)p->next=r;
 D)p=q->next;

(48)以下对结构体类型变量td的定义中,错误的是 C
 A)typedef struct aa
  {
   int n;
   float m;
  }AA;
    AA td;
 B)struct aa
  {
   int n;
  float m;
    } td;
    struct aa td;
 C)struct
  {
   int n;
  float m;
  }aa;
     struct aa td;
 D)struct
 {
 int n;
 float m;
   }td;

(49)以下与函数fseek(fp,0L,SEEK_SET)有相同作用的是 D
 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中的内容是 B
 A)start
 B)end
 C)startend
 D)endrt
填空题(每空2分,共40分)
(1)某二*树中,度为2的结点有18个,则该二*树中有 19  个叶子结点。
(2)在面向对象的方法中,类的实例称为 对象  。
(3)诊断和改正程序中错误的工作通常称为 程序调试 。
(4)在关系数据库中,把数据表示成二维表,每一个二维表称为 关系 。
(5)问题处理方案的正确而完整的描述称为 算法 .
(6)以下程序运行时若从键盘输入:10 20 30回车>。输出结果是 10 30 0 .
#include
main()
{ int i=0,j=0,k=0;
scanf("%d%*d%d",&i,&j,&k);
printf("%d%d%d\n",i,j,k);
}
(7)以下程序运行后的输出结果是 81 .
#define S(x) 4*x*x+1
main()
{
int i=6,j=8;
printf("%d\n",S(i+j));
}
(8)以下程序运行后的输出结果是 4599
main()
{
int a=3,b=4,c=5,t=99;
if(b if(a printf("%d%d%d\n",a,b,c);
}
(9)以下程序运行后的输出结果是 10 20 0
main()
{
int a,b,c
a=10;b=20;c=(a%bb>1);
printf("%d %d %d\n",a,b,c);
}
(10)以下程序运行后的输出结果是0918273645
main()
{
char c1,c2;
for(c1='0',c2='9';c1 printf("%c%c",c1,c2);
printf("\n");
}
(11)已知字符A的ASCII代码值为65,以下程序运行时若从键盘输入:B33回车>.输出结果是 1B     
#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列二维数组每行元素中的值.请填空. br[i]
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("M",b[i]);
printf("\n");
}
void fun(int m,int n,int ar[][4],int *br)
{
int i,j,x;
for(i=0;i { x=ar[i][0];
for(j=0;j if(x 【12】 =x;
}
(13)以下程序运行后的输出结果是 4 3 3 4
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)以下程序运行后的输出结果是 abcfg
#include "string.h"
void fun(char *s,int p,int k)
{ int i;
for(i=p;i s[i]=s[i+2];
}
main()
{ char s[]="abcdefg";
fun(s,3,strlen(s));
puts(s);
}
(15)以下程序运行后的输出结果是 abcbcc
#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)以下程序运行后的输出结果是 0 10 1 11 2 12
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)以下程序运行后的输出结果是 13431
struct 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
yes!,否则函数返回字符串:no!,并在主函数中输出.所谓回文即正向与反向的拼写都一样,例如:adgda.请填空.
#include "string.h"
char *huiwen(char *str)
{
char *p1,*p2; int i,t=0;
p1=str; p2= ①
for(i=0;i<=strlen(str)/2;i++)
if(*p1++!=*p2--)
{ t=1; break; }
if( ②) return ("yes!");
else return ("no!");
}
main()
{
char str[50];
printf("Input:"); scanf("%s",str);
printf("%s\n", ③ );
}
①str+strlen(str)-1
②t==0或!t  
③huiwen(str)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式