C++4.docx
- 文档编号:12870929
- 上传时间:2023-04-22
- 格式:DOCX
- 页数:14
- 大小:27.87KB
C++4.docx
《C++4.docx》由会员分享,可在线阅读,更多相关《C++4.docx(14页珍藏版)》请在冰豆网上搜索。
C++4
1)下列关于栈叙述正确的是
A)栈顶元素最先能被删除 B)栈顶元素最后才能被删除
C)栈底元素永远不能被删除 D)以上三种说法都不对
(2)下列叙述中正确的是
A)有一个以上根结点的数据结构不一定是非线性结构
B)只有一个根结点的数据结构不一定是线性结构
C)循环链表是非线性结构
D)双向链表是非线性结构
(3)某二叉树共有7个结点,其中叶子结点只有1个,则该二叉树的深度为(假设根结点在第1层)
A)3 B)4 C)6 D)7
(4)在软件开发中,需求分析阶段产生的主要文档是
A)软件集成测试计划 B)软件详细设计说明书
C)用户手册 D)软件需求规格说明书
(5)结构化程序所要求的基本结构不包括
A)顺序结构 B)GOTO跳转
C)选择(分支)结构 D)重复(循环)结构
(6)下面描述中错误的是
A)系统总体结构图支持软件系统的详细设计
B)软件设计是将软件需求转换为软件表示的过程
C)数据结构与数据库设计是软件设计的任务之一
D)PAD图是软件详细设计的表示工具
7)负责数据库中查询操作的数据库语言是
A)数据定义语言
B)数据管理语言
C)数据操纵语言
D)数据控制语言
(8)一个教师可讲授多门课程,一门课程可由多个教师讲授。
则实体教师和课程间的联系是
A)1:
1联系 B)1:
m联系
C)m:
1联系 D)m:
n联系
(9)有三个关系R、S和T如下:
则由关系R和S得到关系T的操作是
A)自然连接 B)交 C)除 D)并
(10)定义无符号整数类为UInt,下面可以作为类UInt实例化值的是
A)-369 B)369 C)0.369 D)整数集合{1,2,3,4,5}
(11)为了提高函数调用的实际运行速度,可以将较简单的函数定义为
A)内联函数 B)重载函数 C)递归函数 D)函数模板
(12)若AA为一个类,a为该类的非静态数据成员,在该类的一个成员函数定义中访问a时,其书写格式为
A)a B)AA.a C)a() D)AA:
:
a()
(13)以下选项中不能用作C程序合法常量的是
A)1,234 B)'123'
C)123 D)"\x7G"
(14)以下选项中可用作C程序合法实数的是
A).1e0 B)3.0e0.2
C)E9 D)9.12E
(15)若有定义语句:
inta=3,b=2,c=1;,以下选项中错误的赋值表达式是
A)a=(b=4)=3;B)a=b=c+1;
C)a=(b=4)+c;D)a=1+(b=c=4);
(16)有以下程序段
charname[20];
intnum;
scanf("name=%snum=%d",name;&num);
当执行上述程序段,并从键盘输入:
name=Lilinum=1001<回车>后,name的值为
A)Lili
B)name=Lili
C)Lilinum=
D)name=Lilinum=1001
(17)if语句的基本形式是:
if(表达式)语句,以下关于“表达式”值的叙述中正确的是
A)必须是逻辑值 B)必须是整数值
C)必须是正数 D)可以是任意合法的数值
18)有以下程序
#include
main()
{intx=011;
printf("%d\n",++x);
}
程序运行后的输出结果是
A)12 B)11 C)10 D)9
(19)有以下程序
#include
main()
{ints;
scanf("%d",&s);
while(s>0)
{switch(s)
{case1:
printf("%d",s+5);
case2:
printf("%d",s+4);break;
case3:
printf("%d",s+3);
default:
printf("%d",s+1);break;
}
scanf("%d",&s);
}
}
运行时,若输入123450<回车>,则输出结果是
A)6566456 B)66656 C)66666 D)6666656
(20)有以下程序段
inti,n;
for(i=0;i<8;i++)
{n=rand()%5;
switch(n)
{case1:
case3:
printf("%d\n",n);break;
case2:
case4:
printf("%d\n",n);continue;
case0:
exit(0);
}
printf("%d\n",n);
}
以下关于程序段执行情况的叙述,正确的是
A)for循环语句固定执行8次
B)当产生的随机数n为4时结束循环操作
C)当产生的随机数n为1和2时不做任何操作
D)当产生的随机数n为0时结束程序运行
(21)有以下程序
#include
main()
{chars[]="012xy\08s34f4w2";
inti,n=0;
for(i=0;s[i]!
=0;i++)
if(s[i]>='0'&&s[i]<='9')n++;
printf("%d\n",n);
}
程序运行后的输出结果是
A)0 B)3 C)7 D)8
(22)若i和k都是int类型变量,有以下for语句
for(i=0,k=-1;k=1;k++)printf("*****\n");
下面关于语句执行情况的叙述中正确的是
A)循环体执行两次
B)循环体执行一次
C)循环体一次也不执行
D)构成无限循环
(23)有以下程序
#include
main()
{charb,c;inti;
b='a';c='A';
for(i=0;i<6;i++)
{if(i%2)putchar(i+b);
elseputchar(i+c);
}printf("\n");
}
程序运行后的输出结果是
A)ABCDEF B)AbCdEf C)aBcDeF D)abcdef
(24)设有定义:
doublex[10],*p=x;,以下能给数组x下标为6的元素读入数据的正确语句是
A)scanf("%f",&x[6]); B)scanf("%lf",*(x+6));
C)scanf("%lf",p+6); D)scanf("%lf",p[6]);
(25)有以下程序(说明:
字母A的ASCII码值是65)
#include
voidfun(char*s)
{while(*s)
{if(*s%2) printf("%c",*s);
s++;
}
}
main()
{chara[]="BYTE";
fun(a);printf("\n");
}
程序运行后的输出结果是
A)BY B)BT C)YT D)YE
(26)有以下程序段
#include
main()
{…
while(getchar()!
='\n');
…
}
以下叙述中正确的是
A)此while语句将无限循环
B)getchar()不可以出现在while语句的条件表达式中
C)当执行此while语句时,只有按回车键程序才能继续执行
D)当执行此while语句时,按任意键程序就能继续执行
27)有以下程序
#include
main()
{intx=1,y=0;
if(!
x)y++;
elseif(x==0)
if(x)y+=2;
elsey+=3;
printf("%d\n",y);
}
程序运行后的输出结果是
A)3 B)2 C)1 D)0
(28)若有定义语句:
chars[3][10],(*k)[3],*p;,则以下赋值语句正确的是
A)p=s; B)p=k; C)p=s[0]; D)k=s;
(29)有以下程序
#include
voidfun(char*c)
{while(*c)
{if(*c>='a'&&*c<='z')*c=*c-('a'-'A');
c++;
}
}
main()
{chars[81];
gets(s);fun(s);puts(s):
}
当执行程序时从键盘上输入HelloBeijing<回车>,则程序的输出结果是
A)hellobeijingB)HelloBeijingC)HELLOBEIJINGD)hELLOBeijing
(30)以下函数的功能是:
通过键盘输入数据,为数组中的所有元素赋值。
#include
#defineN10
voidfun(intx[N])
{inti=0;
while(i } 在程序中下划线处应填入的是 A)x+i B)&x[i+1] C)x+(i++) D)&x[++i] (31)有以下程序 #include main() {chara[30],b[30]; scanf("%s",a); gets(b); printf("%s\n%s\n",a,b); } 程序运行时若输入: howareyou? Iamfine<回车> 则输出结果是 A)howareyou? B)how Iamfine areyou? Iamfine C)howareyou? Iamfine D)rowareyou? (32)设有如下函数定义 intfun(intk) {if(k<1)return0; elseif(k==1)return1; elsereturnfun(k-1)+1; } 若执行调用语句: n=fun(3);,则函数fun总共被调用的次数是 A)2 B)3 C)4 D)5 (33)有以下程序 #include intfun(intx,inty) {if(x! =y)return((x+y);2); elsereturn(x); } main() {inta=4,b=5,c=6; printf("%d\n",fun(2*a,fun(b,c))); } 程序运行后的输出结果是 A)3 B)6 C)8 D)12 (34)有以下程序 #include intfun() {staticintx=1; x*=2; returnx; } main() {inti,s=1; for(i=1;i<=3;i++)s*=fun(); printf("%d\n",s); } 程序运行后的输出结果是 A)0 B)10 C)30 D)64 35)有以下程序 #include #defineS(x)4*(x)*x+1 main() {intk=5,j=2; printf("%d\n",S(k+j)); } 程序运行后的输出结果是 A)197 B)143 C)33 D)28 (36)设有定义: struct{charmark[12];intnum1;doublenum2;}t1,t2;,若变量均已正确赋初值,则以下语句中错误的是 A)t1=t2; B)t2.num1=t1.num1; C)t2.mark=t1.mark; D)t2.num2=t1.num2; (37)有以下程序 #include structord {intx,y;}dt[2]={1,2,3,4}; main() { structord*p=dt; printf("%d,",++(p->x));printf("%d\n",++(p->y)); } 程序运行后的输出结果是 A)1,2 B)4,1 C)3,4 D)2,3 38)有以下程序 #include structS {inta,b;}data[2]={10,100,20,200}; main() {structSp=data[1]; printf("%d\n",++(p.a)); } 程序运行后的输出结果是 A)10 B)11 C)20 D)21 (39)有以下程序 #include main() {unsignedchara=8,c; c=a>>3; printf("%d\n",c); } 程序运行后的输出结果是 A)32 B)16 C)1 D)0 (40)设fp已定义,执行语句fp=fopen("file","w");后,以下针对文本文件file操作叙述的选项中正确的是 A)写操作结束后可以从头开始读 B)只能写不能读 C)可以在原有内容后追加写 D)可以随意读和写 1)有序线性表能进行二分查找的前提是该线性表必须是【1】存储的。 (2)一棵二叉树的中序遍历结果为DBEAFC,前序遍历结果为ABDECF,则后序遍历结果为【2】。 (3)对软件设计的最小单位(模块或程序单元)进行的测试通常称为【3】测试。 (4)实体完整性约束要求关系数据库中元组的【4】属性值不能为空。 (5)在关系A(S,SN,D)和关系B(D,CN,NM)中,A的主关键字是S,B的主关键字是D,则称【5】是关系A的外码。 (6)以下程序运行后的输出结果是【6】。 #include main() {inta; a=(int)((double)(3/2)+0.5+(int)1.99*2); printf("%d\n",a); } (7)有以下程序 #include main() {intx; scanf("%d",&x); if(x>15)printf("%d",x-5); if(x>10)printf("%d",x); if(x>5)printf("%d\n",x+5); } 若程序运行时从键盘输入12<回车>,则输出结果为【7】。 (8)有以下程序(说明: 字符0的ASCII码值为48) #include main() {charc1,c2; scanf("%d",&c1); c2=c1+9; printf("%c%c\n",c1,c2); } 若程序运行时从键盘输入48<回车>,则输出结果为【8】。 (9)有以下函数 voidprt(charch,intn) {inti; for(i=1;i<=n;i++) printf(i%6! =0? "%c": "%c\n",ch); } 执行调用语句prt('*',24);后,函数共输出了【9】行*号。 (10)以下程序运行后的输出结果是【10】。 #include main() {intx=10,y=20,t=0; if(x==y)t=x;x=y;y=t; printf("%d%d\n",x,y); } (11)己知a所指的数组中有N个元素。 函数fun的功能是,将下标k(k>0)开始的后续元素全部向前移动一个位置。 请填空。 voidfun(inta[N],intk) {inti; for(i=k;i } (12)有以下程序,请在【12】处填写正确语句,使程序可正常编译运行。 #include 【12】; main() {doublex,y,(*p)(); scanf("%lf%lf",&x,&y); p=avg; printf("%f\n",(*p)(x,y)); } doubleavg(doublea,doubleb) {return((a+b)/2);} (13)以下程序运行后的输出结果是【13】。 #include main() {inti,n[5]={0}; for(i=1;i<=4;i++) {n[i]==n[i-1]*2+1;printf("%d",n[i]);} printf("\n"); } 14)以下程序运行后的输出结果是【14】。 #include #include #include main() {char*p;inti; p=(char*)malloc(sizeof(char)*20); strcpy(p,"welcome"); for(i=6;i>=0;i--)putchar(*(p+i)); printf("\n-");free(p); } (15)以下程序运行后的输出结果是【15】。 #include main() {FILE*fp;intx[6]={1,2,3,4,5,6},i; fp=fopen("test.dat","wb"); fwrite(x,sizeof(int),3,fp); rewind(fp); fread(x,sizeof(int),3,fp); for(i=0;i<6;i++)printf("%d",x[i]); printf("\n"); fclose(fp); } 一、选择题(每小题2分,共70分)下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的,请将正确选项涂写在答题卡相应位置上,答在试卷上不得分。 (1)下列关于栈的叙述中正确的是 A)在栈中只能插入数据 B)在栈中只能删除数据 C)栈是先进先出的线性表 D)栈是先进后出的线性表 (2)下列数据结构中,插入时不需要移动其他元素的是 A)有序线性链表 B)无序线性链表 C)栈和队列 D)以上三种都是 (3)下列叙述中正确的是 A)同一个数据结构不管是采用何种存储方式,其所占的存储容量一定是相同的 B)同一个数据结构采用不同的存储方式,其所占的存储容量一般是不同的 C)同一个有序表不管是采用何种存储方式,都可以使用对分查找法 D)同一个有序表不管是采用何种存储方式,都不能使用对分查找法 (4)数据结构分为逻辑结构和存储结构,下列数据结构中不属于存储结构的是 A)线性链表 B)二叉链表 C)栈与队列 D)循环队列 (5)下列数据结构中,能直接使用堆排序法进行排序的是 A)完全二叉树 B)线性链表 C)带链的栈 D)带链的队列 (6)下列关于队列的叙述中正确的是 A)只能插入元素,而不能删除元素 B)可以插入元素,也能删除元素 C)插入元素时需要移动队列中所有的元素 D)删除元素时需要移动队列中所有的元素 (7)下列叙述中正确的是 A)在模块化程序设计中,一个模块应尽量多的包括与其他模块联系的信息 B)在自顶向下、逐步细化的设计过程中,首先应设计解决问题的每一个细节 C)在模块化程序设计中,一个模块内部的控制结构也要符合结构化原则 D)在程序设计过程中,不能同时采用结构化程序设计方法与模块化程序设计方法 (8)数据独立性是数据库技术的重要特点之一。 所谓数据独立性是指 A)数据与程序独立存放 B)不同的数据被存放在不同的文件中 C)不同的数据只能被对应的应用程序所使用 D)以上三种说法都不对 (9)用树
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- C+