[计算机类试卷]2012年3月国家二级(C++)笔试真题试卷及答案与解析.doc
《[计算机类试卷]2012年3月国家二级(C++)笔试真题试卷及答案与解析.doc》由会员分享,可在线阅读,更多相关《[计算机类试卷]2012年3月国家二级(C++)笔试真题试卷及答案与解析.doc(22页珍藏版)》请在麦多课文档分享上搜索。
1、2012 年 3月国家二级( C+)笔试真题试卷及答案与解析 1 假设线性表的长度为 n,则在最坏情况下,冒泡排序需要的比较次数为 ( A) log2n ( B) n2 ( C) O(n1.5) ( D) n(n-1)/2 2 算法分析的目的是 ( A)找出数据结构的合理性 ( B)找出算法中输入和输出之间的关系 ( C)分析算法的易懂性和可靠性 ( D)分析算法的效率以求改进 3 线性表 L=(a1,a2,a3,ai , an) ,下列说法正确的是 ( A)每个元素都有一个直接前件和直接后件 ( B)线性表中至 少要有一个元素 ( C)表中诸元素的排列顺序必须是由小到大或由大到小 ( D)除
2、第一个元素和最后一个元素外,其余每个元素都有一个且只有一个直接前件和直接后件 4 在单链表中,增加头结点的目的是 ( A)方便运算的实现 ( B)使单链表至少有一个结点 ( C)标识表结点中首结点的位置 ( D)说明单链表是线性表的链式存储实现 5 软件工程的出现是由于 ( A)程序设计方法学的影响 ( B)软件产业化的需要 ( C)软件危机的出现 ( D)计算机的发展 6 软件开发离不开系统环境资源的支持,其中必要 的测试数据属于 ( A)硬件资源 ( B)通信资源 ( C)支持软件 ( D)辅助资源 7 在数据流图 (DFD) 中,带有名字的箭头表示 ( A)模块之间的调用关系 ( B)程
3、序的组成成分 ( C)控制程序的执行顺序 ( D)数据的流向 8 分布式数据库系统不具有的特点是 ( A)数据分布性和逻辑整体性 ( B)位置透明性和复制透明性 ( C)分布性 ( D)数据冗余 9 关系表中的每一横行称为一个 ( A)元组 ( B)字段 ( C)属性 ( D)码 10 下列数据模型中,具有坚实理论基础 的是 ( A)层次模型 ( B)网状模型 ( C)关系模型 ( D)以上 3个都是 11 下列字符串中可以用作 C+语言标识符的是 ( A) _1234 ( B) foo bar ( C) virtual ( D) 34var 12 关于 C+语言与 C语言关系描述中错误的是
4、( A) C+语言是 C语言的超集 ( B) C+语言对 C语言进行了扩充 ( C) C+语言包含 C语言的全部语法特征 ( D) C+语言与 C语言都是面向对象的程序设计语言 13 下列语句的输出结果 cout strlen(“t“065xffn“); ( A) 5 ( B) 14 ( C) 8 ( D)输出项不合法,无正常输出 14 在 C+语言中,不合法的实型数据的是 ( A) 0.123 ( B) 123e3 ( C) 2.1e3.5 ( D) 123.0 15 若有如下语句 #include void main() int x=3; do x=x-2; cout x; while(!
5、(-x); 则上面程序段 ( A)输出的是 1 ( B)输出的是 1和 -2 ( C)输出 的是 3和 0 ( D)是死循环 16 下面有关 for循环的正确描述是 ( A) for循环只能用于循环次数已经确定的情况 ( B) for循环是先执行循环体语句,后判断表达式 ( C)在 for循环中,不能用 break语句跳出循环体 ( D) for循环的循环体语句中,可以包含多条语句,但必须用花括号括起来 17 以下程序中调用 cin函数给变量 a输入数值的方法是错误的,其错误原因是 #include void main() int *p,*q,a,b; p= cout “input a:“;
6、cin p; ( A) *p表示的是指针变量 p的地址 ( B) p表示的是变量 a的地址,而不是变量 a的值 ( C) *p表示的是指针变量 p的值 ( D) *p只能用来说明 p是一个指针变量 18 假定 int类型变量占用两个字节,其有定义 int x10=0,2,4;,则数组 x在内存中所占字节数是 ( A) 3 ( B) 6 ( C) 10 ( D) 20 19 有以下程序 #include void fun(int a,int b,int c) a=456,b=567,c=678; void main() int x=10,y=20,z=30; fun(x,y,z); cout x
7、 , y , z endl; 输出结果是 ( A) 30,20,10 ( B) 10,20,30 ( C) 456,567,678 ( D) 678,567,456 20 以下叙述正确的是 ( A)函数可以嵌套定义但不能嵌套调用 ( B)函数既可以嵌套调用也可以嵌套定义 ( C)函数既不可以嵌套定义也不可以嵌套调用 ( D)函数可以嵌套 调用但不可以嵌套定义 21 下列定义中 p指向的地址可更改,但 *p不能够更改的是 ( A) const int *p; ( B) int * const p; ( C) const int * const p; ( D) int *p; 22 下面的语句中错
8、误的是 ( A) int a=5; int xa; ( B) const int a=5; int xa; ( C) int n=5; int *p=new int a; ( D) const int n=5; int *p=new int a; 23 下面程序的结果是 #include class A int a; public: A():a (1) void showa()cout a; ; class B int a; public: B():a (2) void showa()cout a; ; class C:public A, public B int a; public: C()
9、:a (3) void showa()cout a; ; void main() C c; c.showa(); ( A) 1 ( B) 2 ( C) 3 ( D)程序有错误 24 关于二义性的描述错误的是 ( A)一个子类的两个父类中都有某个同名成员,在子类中对该成员访问可能出现二义性 ( B)解决二义性可以用对成员名的限定法 ( C)父类和子类中同时出现同名函数,也可能存在二义性 ( D)一个子类是从两个父类派生出来的,而这两个父类又有一个共同的父类,对该父类成员进行访问时,可能出现二义性 25 如果表达式 x*y+z 中, “*“是作为友元函数重载的, “+“是作为友元函数重载的 ,则该
10、表达式还可为 ( A) operator+(operator*(x, y),z) ( B) x.operator+(operator*(x, y),z) ( C) y.operator*(operator+(x, y),z) ( D) x.operator+(operator*(x, y) 26 函数模板: template T add(T x,T y)return x+y; 下列对 add函数的调用不正确的 是 ( A) add (1,2) ( B) add(1,2) ( C) add(1.0,2) ( D) add(1.0,2.0) 27 对于语句 cout setfill(*) setw
11、(10) 1 setfill(*) setw (2) 2;的输出结果是 ( A) *1*2 ( B) *12 ( C) *1*2 ( D) 12* 28 this指针是 C+语言实现什么的一种机制 ? ( A)抽象 ( B)封装 ( C)继承 ( D)重载 29 有如下程序 #include int func(int a,int b) return(a+b); void main() int x=2,y=5,z=8,r; r=func(func(x,y),z); cout r; 该程序的输出的结果是 ( A) 12 ( B) 13 ( C) 14 ( D) 15 30 下列描述中,抽象类的特性
12、是 ( A)可以说明虚函数 ( B)可以定义友元函数 ( C)可以进行构造函数重载 ( D)不能说明其对象 31 在 C+语言中,打开一个文件就是将这个文件与一个什么建立关联 ? ( A)流 ( B)类 ( C)结构 ( D)对象 32 下列程序的运行结果是 #include void fun(int *a, int *b) int *k; k=a; a=b; b=k; void main() int a=3, b=6, *x= fun(x,y); cout a “ “ b; ( A) 6 3 ( B) 3 6 ( C)编译出错 ( D) 0 0 33 执行语句 for(i=1;i+ 4;);
13、,后变量 i的值是 ( A) 3 ( B) 4 ( C) 5 ( D)不定 34 判断 char型变量 c是否为小写字母的正确表达式是 ( A) a =c =z ( B) (c =A) a+=(a=8); cout a; 46 若要在 C盘根目录下作为二进制文件打开文件 test.dat,则应该用的语句是_。 46 下面程序的运行结果是 1_和 2_。 #include #define N 10 #define s(x)x*x #define f(x)(x*x) void main() int i1,i2; i1=1000/s(N); i2=1000/f(N); cout i1 “ “ i2;
14、 47 1_ 48 2_。 48 1_是实现 C+语言编译时多态性的机制, 2_是实现 C+语言运行时多态性的机制。 49 1_ 50 2_。 2012 年 3月国家二级( C+)笔试真题试卷答案与解析 1 【正确答案】 D 【试题解析】 假设线性表的长度为 n,则在最坏情况下,冒泡排序要经过 n/2遍的从前往后的扫描和 n/2遍的从后往前的扫描,需要的比较次数为 n(n-1)/2。 2 【正确答案】 D 【试题解析】 算法分析是指对一个算法的运行时间和占用空间做定量的分析,一般计算出相应的数量级,常用时间复杂度和空间复杂度表示。分析算法的目的就是要降低算法的时间复杂度和空间复杂度,提高算法的
15、执行效率。 3 【正确答案】 D 【试题解析】 线性表可以为空表;第一个元素没有直接前件,最后一个元素没有直接后件;线性表的定义中,元素的排列并没有规定大小顺序。 4 【正确答案】 A 【试题解析】 头结点不仅标识了表中首结点的位置,而且根据单链表 (包含头结点 )的结构,只要掌握了表头,就能够访问整个链表,因此增加头结点目的是为了便于运算的实现。 5 【正确答案】 C 【试题解析】 软件工程概念的出现源自于软件危机。为了消除软件危机,通过认真研究解决软件危机的方法,认识到软件工程是使计算机软件走向工程科学的途径,逐步形成了软件工程的概念。 6 【正确答案】 D 【试题解析】 软件测试过程中,
- 1.请仔细阅读文档,确保文档完整性,对于不预览、不比对内容而直接下载带来的问题本站不予受理。
- 2.下载的文档,不会出现我们的网址水印。
- 3、该文档所得收入(下载+内容+预览)归上传者、原创作者;如果您是本文档原作者,请点此认领!既往收益都归您。
下载文档到电脑,查找使用更方便
2000 积分 0人已下载
下载 | 加入VIP,交流精品资源 |
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机 试卷 2012 国家 二级 笔试 答案 解析 DOC
