C语言二级考试试题及答案(2007~2009)

申明敬告: 本站不保证该用户上传的文档完整性,不预览、不比对内容而直接下载产生的反悔问题本站不予受理。

文档介绍

C语言二级考试试题及答案(2007~2009)

2007年四月计算机二级试题一选择题(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)DYBEAFCZXB)YDEBFZXCAC)ABDYECFXZD)ABCDEFXYZ(7)某二叉树中有n个度为2的结点,则该二叉树中的叶子结点为A)n+1B)n-1C)2nD)n/2(8)在下列关系运算中,不改变关系表中的属性个数但能减少元组个数的是A)并B)交C)投影D)笛卡儿乘积(9)在E-R图中,用来表示实体之间联系的图形是A)矩形B)椭圆形C)菱形D)平行四边形(10)下列叙述中错误的是A)在数据库系统中,数据的物理结构必须与逻辑结构一致B)数据库技术的根本目标是要解决数据的共享问题C)数据库设计是指在已有数据库管理系统的基础上建立数据库D)数据库系统需要操作系统的支持(11)算法中,对需要执行的每一步操作,必须给出清楚、严格的规定,这属于算法的A)正当性B)可行性C)确定性D)有穷性(12)下列叙述中错误的是n2007年四月计算机二级试题一选择题(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)DYBEAFCZXB)YDEBFZXCAC)ABDYECFXZD)ABCDEFXYZ(7)某二叉树中有n个度为2的结点,则该二叉树中的叶子结点为A)n+1B)n-1C)2nD)n/2(8)在下列关系运算中,不改变关系表中的属性个数但能减少元组个数的是A)并B)交C)投影D)笛卡儿乘积(9)在E-R图中,用来表示实体之间联系的图形是A)矩形B)椭圆形C)菱形D)平行四边形(10)下列叙述中错误的是A)在数据库系统中,数据的物理结构必须与逻辑结构一致B)数据库技术的根本目标是要解决数据的共享问题C)数据库设计是指在已有数据库管理系统的基础上建立数据库D)数据库系统需要操作系统的支持(11)算法中,对需要执行的每一步操作,必须给出清楚、严格的规定,这属于算法的A)正当性B)可行性C)确定性D)有穷性(12)下列叙述中错误的是n2007年四月计算机二级试题一选择题(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)DYBEAFCZXB)YDEBFZXCAC)ABDYECFXZD)ABCDEFXYZ(7)某二叉树中有n个度为2的结点,则该二叉树中的叶子结点为A)n+1B)n-1C)2nD)n/2(8)在下列关系运算中,不改变关系表中的属性个数但能减少元组个数的是A)并B)交C)投影D)笛卡儿乘积(9)在E-R图中,用来表示实体之间联系的图形是A)矩形B)椭圆形C)菱形D)平行四边形(10)下列叙述中错误的是A)在数据库系统中,数据的物理结构必须与逻辑结构一致B)数据库技术的根本目标是要解决数据的共享问题C)数据库设计是指在已有数据库管理系统的基础上建立数据库D)数据库系统需要操作系统的支持(11)算法中,对需要执行的每一步操作,必须给出清楚、严格的规定,这属于算法的A)正当性B)可行性C)确定性D)有穷性(12)下列叙述中错误的是n2007年四月计算机二级试题一选择题(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)DYBEAFCZXB)YDEBFZXCAC)ABDYECFXZD)ABCDEFXYZ(7)某二叉树中有n个度为2的结点,则该二叉树中的叶子结点为A)n+1B)n-1C)2nD)n/2(8)在下列关系运算中,不改变关系表中的属性个数但能减少元组个数的是A)并B)交C)投影D)笛卡儿乘积(9)在E-R图中,用来表示实体之间联系的图形是A)矩形B)椭圆形C)菱形D)平行四边形(10)下列叙述中错误的是A)在数据库系统中,数据的物理结构必须与逻辑结构一致B)数据库技术的根本目标是要解决数据的共享问题C)数据库设计是指在已有数据库管理系统的基础上建立数据库D)数据库系统需要操作系统的支持(11)算法中,对需要执行的每一步操作,必须给出清楚、严格的规定,这属于算法的A)正当性B)可行性C)确定性D)有穷性(12)下列叙述中错误的是n2007年四月计算机二级试题一选择题(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)DYBEAFCZXB)YDEBFZXCAC)ABDYECFXZD)ABCDEFXYZ(7)某二叉树中有n个度为2的结点,则该二叉树中的叶子结点为A)n+1B)n-1C)2nD)n/2(8)在下列关系运算中,不改变关系表中的属性个数但能减少元组个数的是A)并B)交C)投影D)笛卡儿乘积(9)在E-R图中,用来表示实体之间联系的图形是A)矩形B)椭圆形C)菱形D)平行四边形(10)下列叙述中错误的是A)在数据库系统中,数据的物理结构必须与逻辑结构一致B)数据库技术的根本目标是要解决数据的共享问题C)数据库设计是指在已有数据库管理系统的基础上建立数据库D)数据库系统需要操作系统的支持(11)算法中,对需要执行的每一步操作,必须给出清楚、严格的规定,这属于算法的A)正当性B)可行性C)确定性D)有穷性(12)下列叙述中错误的是n2007年四月计算机二级试题一选择题(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)DYBEAFCZXB)YDEBFZXCAC)ABDYECFXZD)ABCDEFXYZ(7)某二叉树中有n个度为2的结点,则该二叉树中的叶子结点为A)n+1B)n-1C)2nD)n/2(8)在下列关系运算中,不改变关系表中的属性个数但能减少元组个数的是A)并B)交C)投影D)笛卡儿乘积(9)在E-R图中,用来表示实体之间联系的图形是A)矩形B)椭圆形C)菱形D)平行四边形(10)下列叙述中错误的是A)在数据库系统中,数据的物理结构必须与逻辑结构一致B)数据库技术的根本目标是要解决数据的共享问题C)数据库设计是指在已有数据库管理系统的基础上建立数据库D)数据库系统需要操作系统的支持(11)算法中,对需要执行的每一步操作,必须给出清楚、严格的规定,这属于算法的A)正当性B)可行性C)确定性D)有穷性(12)下列叙述中错误的是n2007年四月计算机二级试题一选择题(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)DYBEAFCZXB)YDEBFZXCAC)ABDYECFXZD)ABCDEFXYZ(7)某二叉树中有n个度为2的结点,则该二叉树中的叶子结点为A)n+1B)n-1C)2nD)n/2(8)在下列关系运算中,不改变关系表中的属性个数但能减少元组个数的是A)并B)交C)投影D)笛卡儿乘积(9)在E-R图中,用来表示实体之间联系的图形是A)矩形B)椭圆形C)菱形D)平行四边形(10)下列叙述中错误的是A)在数据库系统中,数据的物理结构必须与逻辑结构一致B)数据库技术的根本目标是要解决数据的共享问题C)数据库设计是指在已有数据库管理系统的基础上建立数据库D)数据库系统需要操作系统的支持(11)算法中,对需要执行的每一步操作,必须给出清楚、严格的规定,这属于算法的A)正当性B)可行性C)确定性D)有穷性(12)下列叙述中错误的是n2007年四月计算机二级试题一选择题(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)DYBEAFCZXB)YDEBFZXCAC)ABDYECFXZD)ABCDEFXYZ(7)某二叉树中有n个度为2的结点,则该二叉树中的叶子结点为A)n+1B)n-1C)2nD)n/2(8)在下列关系运算中,不改变关系表中的属性个数但能减少元组个数的是A)并B)交C)投影D)笛卡儿乘积(9)在E-R图中,用来表示实体之间联系的图形是A)矩形B)椭圆形C)菱形D)平行四边形(10)下列叙述中错误的是A)在数据库系统中,数据的物理结构必须与逻辑结构一致B)数据库技术的根本目标是要解决数据的共享问题C)数据库设计是指在已有数据库管理系统的基础上建立数据库D)数据库系统需要操作系统的支持(11)算法中,对需要执行的每一步操作,必须给出清楚、严格的规定,这属于算法的A)正当性B)可行性C)确定性D)有穷性(12)下列叙述中错误的是n2007年四月计算机二级试题一选择题(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)DYBEAFCZXB)YDEBFZXCAC)ABDYECFXZD)ABCDEFXYZ(7)某二叉树中有n个度为2的结点,则该二叉树中的叶子结点为A)n+1B)n-1C)2nD)n/2(8)在下列关系运算中,不改变关系表中的属性个数但能减少元组个数的是A)并B)交C)投影D)笛卡儿乘积(9)在E-R图中,用来表示实体之间联系的图形是A)矩形B)椭圆形C)菱形D)平行四边形(10)下列叙述中错误的是A)在数据库系统中,数据的物理结构必须与逻辑结构一致B)数据库技术的根本目标是要解决数据的共享问题C)数据库设计是指在已有数据库管理系统的基础上建立数据库D)数据库系统需要操作系统的支持(11)算法中,对需要执行的每一步操作,必须给出清楚、严格的规定,这属于算法的A)正当性B)可行性C)确定性D)有穷性(12)下列叙述中错误的是n2007年四月计算机二级试题一选择题(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)DYBEAFCZXB)YDEBFZXCAC)ABDYECFXZD)ABCDEFXYZ(7)某二叉树中有n个度为2的结点,则该二叉树中的叶子结点为A)n+1B)n-1C)2nD)n/2(8)在下列关系运算中,不改变关系表中的属性个数但能减少元组个数的是A)并B)交C)投影D)笛卡儿乘积(9)在E-R图中,用来表示实体之间联系的图形是A)矩形B)椭圆形C)菱形D)平行四边形(10)下列叙述中错误的是A)在数据库系统中,数据的物理结构必须与逻辑结构一致B)数据库技术的根本目标是要解决数据的共享问题C)数据库设计是指在已有数据库管理系统的基础上建立数据库D)数据库系统需要操作系统的支持(11)算法中,对需要执行的每一步操作,必须给出清楚、严格的规定,这属于算法的A)正当性B)可行性C)确定性D)有穷性(12)下列叙述中错误的是n2007年四月计算机二级试题一选择题(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)DYBEAFCZXB)YDEBFZXCAC)ABDYECFXZD)ABCDEFXYZ(7)某二叉树中有n个度为2的结点,则该二叉树中的叶子结点为A)n+1B)n-1C)2nD)n/2(8)在下列关系运算中,不改变关系表中的属性个数但能减少元组个数的是A)并B)交C)投影D)笛卡儿乘积(9)在E-R图中,用来表示实体之间联系的图形是A)矩形B)椭圆形C)菱形D)平行四边形(10)下列叙述中错误的是A)在数据库系统中,数据的物理结构必须与逻辑结构一致B)数据库技术的根本目标是要解决数据的共享问题C)数据库设计是指在已有数据库管理系统的基础上建立数据库D)数据库系统需要操作系统的支持(11)算法中,对需要执行的每一步操作,必须给出清楚、严格的规定,这属于算法的A)正当性B)可行性C)确定性D)有穷性(12)下列叙述中错误的是nA)计算机不能直接执行用C语言编写的源程序B)C程序经C编译后,生成后缀为.obj的文件是一个二进制文件C)后缀为.obj的文件,经连接程序生成后缀为.exe的文件是一个二进制文件D)后缀为.obj和.exe的二进制文件都可以直接运行(13)按照C语言规定的用户标识符命名规则,不能出现在标识符中的是A)大写字母B)连接符C)数字字符D)下划线(14)以下叙述中错误的是A)C语言是一种结构化程序设计语言B)结构化程序有顺序、分支、循环三种基本结构组成C)使用三种基本结构构成的程序只能解决简单问题D)结构化程序设计提倡模块化的设计方法(15)对于一个正常运行的C程序,以下叙述中正确的是A)程序的执行总是从main函数开始,在main函数结束B)程序的执行总是从程序的第一个函数开始,在main函数结束C)程序的执行总是从main函数开始,在程序的最后一个函数中结束D)程序的执行总是从程序的第一个函数开始,在程序的最后一个函数中结束(16)设变量均已正确定义,若要通过scanf(“%d%c%d%c”,&a1,&c1,&a2,&c2);语句为变量a1和a2赋数值10和20,为变量c1和c2赋字符X和Y。以下所示的输入形式正确的是(注:□代表空格字符)A)10□X□20□Y〈回车〉B)10□X20□Y〈回车〉C)10□X〈回车〉D)10X〈回车〉20□Y〈回车〉20Y〈回车〉(17)若有代数式(其中e仅代表自然对数的底数,不是变量),则以下能够正确表示该代数式的C语言表达式是A)sqrt(abs(n^x+e^x))B)sqrt(fabs(pow(n,x)+pow(x,e)))C)sqrt(fabs(pow(n,x)+exp(x,e)))D)sqrt(fabs(pow(x,nn)+exp(x)))(18)设有定义:intk=0;,以下选项的四个表达式中与其他三个表达式的值不相同的是A)k++B)k+=1C)++kDD)k+1(19)有以下程序,其中%u表示按无呼号整数输出Main(){unsignedintx=0xFFFF;/*x的初值为十六进制数*/Printf(“%un”,x);}程序运行后的输出结果是A)-1B)65535C)32767D)0XFFFF(20)设变量x和y均已正确定义并赋值,以下if语句中,在编译时将产生错误信息的是A)if(x++)B)if(x>y&y!=0);C)if(x>y)x--D)if(y<0){;}elsey++:elsex++;(21)以下选项中,当x为大于1的奇数时,值为0的表达式A)x%2==1B)x/2C)x%2!=0D)x%2==0(22)以下叙述中正确的是nA)break语句只能用于switch语句题中B)continue语句的作用是:使程序的执行流程跳出包含它的所有循环C)break语句只能用在循环体内和switch语句体内D)在循环体内使用break语句和continue语句的作用相同(23)有以下程序Main(){intk=5,n=0;do{switch(k){case1:case3:n+=1;break;Default;n=0;k--;Case2:case4:n+=2;k--;break;}Printf(“%d”,n);}while(k>0&&n<5);}程序运行后的输出结果是A)235B)0235C)02356D)2356(24)有以下程序mian(){inti,j;for(i=1;i<4;i++){for(j=i;j<4;j++)printf(“%d*%d=%d“,i,j,i*j);Printf(“n”);}}程序运行后的输出结果是*p=&n;Printf(“Inputn:”);scanf(“%d”,&p);printf(“outputn:”);printf(“%dn”,p);}该程序试图通过指针p为变量n读入数据并输出,但程序有多处错误,以下语句正确的是A)intn,*p=NULL;B)*p=&n;C)scanf(“%d”,&p)D)printf(“%dn”,p);(31)以下程序中函数f的功能是:当flag为4时,进行有小到大排序;当flag为0时,进行由大到小排序。voidf(intb[],intn,intflag){inti,j,t;for(i=0;ifor(j=i+1;jif(flag?b[i]>b[j]:b[i]}main(){inta[10]={5,4,3,2,1,6,7,8,9,10},I;f(&a[2],5,0);f(a,5,1);for(i=0;i<10;i++)printf(“%d,”a[i]);n}程序运行后的输出结果是A)1,2,3,4,5,6,7,8,9,10,B)3,4,5,6,7,2,1,8,9,10,C)5,4,3,2,1,6,7,8,9,10,D)10,9,8,7,6,5,4,3,2,1,(32)有以下程序voidf(intb[]){intI;for(i=2;i<6;i++)b[i]*=2;}main(){inta[10]={1,2,3,4,5,6,7,8,9,10},i;ffor(i=0;i<10;i++)printf(“%d,”,a[i]);}程序运行后的输出结果是A)1,2,3,4,5,6,7,8,9,10,B)1,2,6,8,10,12,7,8,9,10C)1,2,3,4,10,12,14,16,9,10,D)1,2,6,8,10,12,14,16,9,10,(33)有以下程序typedefstruct{intb,p;}A;voidf(Ac)/*注意:c是结构变量名*/{intj;c.b+=1;c.p+=2;}main(){inti;Aa={1,2};fprintf(“%d,%dn”,a.b,a.p);}程序运行后的输出结果是A)2,3B)2,4C)1,4D)1,2(34)有以下程序main(){inta[4][4]={{1,4,3,2,},{8,6,5,7,},{3,7,2,5,},{4,8,6,1,}},i,j,k,t;for(i=0;i<4;i++)for(j=0;j<3;j++)for(k=j+1;k<4;k++)if(a[j][i]>a[k][i]){t=a[j][i];a[j][i]=a[k][i];a[k][i]=t;}/*按列排序*/for(i=0;i<4;i++)printf(“%d,”,a[i][j]);}程序运行后的输出结果是A)1,6,5,7,B)8,7,3,1,C)4,7,5,2,D)1,6,2,1,(35)有以下程序main()n{inta[4][4]={{1,4,3,2,},{8,6,5,7,},{3,7,2,5,},{4,8,6,1,}},i,k,t;for(i=0;i<3;i++)for(k=i+i;k<4;k++)if(a[i][i]for(i=0;i<4;i++)printf(“%d,”,a[0][i]);}程序运行后的输出结果是A)6,2,1,1,B)6,4,3,2,C)1,1,2,6,D)2,3,4,6,(36)有以下程序voidf(int*q){inti=0;for(i<5;i++)(*q)++;}main(){inta[5]={1,2,3,4,5},i;ffor(i=0;i<5;i++)printf(“%d,”,a[i]);}程序运行后的输出结果是A)2,2,3,4,5,B)6,2,3,4,5,C)2,3,4,5,6,(37)有以下程序#includemain(){charp[20]={‘a’,’b’,’c’,’d’},q[]=”abc”,r[]=”abcde”;Strcpy(p+strlen(q),r);strcat(p,q);Printf(“%d%dn”,sizeof(p),strlen(p));}程序运行后的输出结果是A)209B)99C)2011D)1111(38)有以下程序#includemain(){charp[20]={‘a’,’b’,’c’,’d’},q[]=”abc”,r[]=”abcde”strcat(p,r);Strcpy(p+strlen(q),q);Printf(“%dn”,sizeof(p));}程序运行后的输出结果是A)9B)6C)11D)7(39)有以下程序#includemain(){charp[20]={‘a’,’b’,’c’,’d’},q[]=”abc”,r[]=”abcde”;Strcat(p,r);strcpy(p+strlen(q),q);Printf(“%dn”,strlen(p));}程序运行后的输出结果是nA)9B)6C)11D)7else{inta=7;t+=a++;}returnt+a++;}main(){ints=a,i=0;for(;i〈2;i++〉s+=f(i);printf(“%dn”,s);}程序运行后的输出结果是A)24B)28C)32D)36(43)有一个名为init.txt的文件,内容如下:#defineHDY(A,B)A/B#definePRINT(Y)Printf(“y=%dn.,Y)有以下程序#include“init.txt”main(){inta=1,b=2,c=3,d=4,k;K=HDY(a+c,b+d);PRINT(K);}下面针对该程序的叙述正确的是A)编译有错B)运行出错C)运行结果为y=0D)运行结果为y=6(44)有以下程序Main(){charch[]=“uvwxyz”,*pc;Pc=ch;printf(“%cn”,*(pc+5));}程序运行后的输出结果是A)zB)0C)元素ch[5]地址D)字符y的地址(45)有以下程序structS{intn;inta[20];};voidf(structS*P){inti,j,t;nfor(i=0;in-1;i++)for(j=j+1;jn-1;j++)程序运行后的输出结果是A)3B)4C)5D)6(49)有以下程序#includeMain(){FILE*fp;intI,a[6]={1,2,3,4,5,6};fp=fopen(“d2.dat”,”w”);fprintf(fp,”%d%dn”,a[0],a[1],a[2]);fprintf(fp,“%d%dn”,a[3],a[4],a[5]);fclose(fp);fp=fopen(“d2.dat”,”r”);fscanf(fp,”“%d%dn”,&k,&n);printf(“%d%dn”,k,n);fclose(fp);}程序运行后的输出结果是A)12B)14C)1234D)123456(50)有以下程序#includemain(){fILE*fp;intI,a[6]={1,2,3,4,5,6k};fp=fopen(“d3.dat”,”w+b”);fwrite(a,size(int),6,fp);fseek(fp,sizeof(int)*3,SEEKSET);/*该语句使读文件的位置指针从文件头向后移动3个int型数据*/fread(a,sizeof(int),3,fp);fclose(fp);for(i=0;i<6;i++)printf(“%d,”,a[i]);}程序运行后的输出结果是A)4,5,6,4,5,6,B)1,2,3,4,5,6,C)4,5,6,1,2,3,D)6,5,4,3,2,1,二.填空题(每空2分,共40分)请将每一个空的正确答案写在答题卡[1]至[20]序号的横线上,答在试卷上不得分。注意:以命令关键字填空的必须写完整(1)在深度为7的满二叉树中,度为2的结点个数为_________。(2)软件测试分为白箱(盒)测试和黑箱(盒)测试,等价类划分法属于__________测试。(3)在数据库系统中,实现各种数据管理功能的核心软件称为数据库管理系统______。(4)n软件生命周期可分为多个阶段,一般分为定义阶段、开发阶段和维护阶段。编码和测试属于_______阶段。(5)在结构化分析使用的数据流图(DFD)中,利用_________对其中的图形元素进行确切解释。(6)执行以下程序后的输出结果是__________。main(){inta=10;a=(3*5,a+4);printf(“a=%dn”,a);}(7)当执行以下程序时,输入1234567890<回车>,则其中while循环体将执行___________次。#includemain(){charch;While((ch=getchar())==’0’)printf(“#”);}(8)以下程序的运行结果是_________。intk=0;voidfun(intm){m+=k;k+=m;printf(“m=%dnk=%d”,m,k++);}main(){inti=4;fun(i++);printf(“i=%dk=%dn”,i,k);}(9)以下程序的运行结果是__________。main(){inta=2,b=7,c=5;Switch(a>0){case1:switch(b<0){case1:switch(“@”);break;Case2:printf(“!”);break;}Case0:switch(c==5){case0:printf(“*”);break;Case1:printf(“#”);break;Case2:printf(“$”);break;}default:printf(“&”);}Printf(“n”);}(10)以下程序的输出结果是____________#includemain(){printf(“%dn”,strlen(“IBMn0121\”));n}(11)已定义charch=”$”;inti=1,j;执行j=!ch&&i++以后,i的值为___________(12)以下程序的输出结果是________#includemain(){chara[]={‘1’,’2’,’3’,’4’,’’};Printf(“%d%dn”,sizeof,srelen);}(13)设有定义语句:inta[][3]={{0},{1},{2}};,则数组元素a[1][2]的值为________(14)以下程序的功能是:求出数组x中各相邻两个元素的和,依次存放到a数组中,然后输出,请填空。Main(){intx[10],a[9],I;For(i=0;i<10;i++)Scanf(“%d”,&x[i]);For(_________i<10;i++)A[i-1]=x[i]+_____________For(i=0;i<9;i++)Printf(“%d”,a[i]);Printf(“n”);(15)以下程序的功能是:利用指针指向三个整型变量,并通过指针运算找出三个数中的最大值,输出到屏幕上,请填空:Main(){intx,y,z,max,*px,*py,*pz,*pmax;Scanf(“%d%d%d”,&x,&y,&z);Px=&x;Py=&y;Pz=&z;Pmax=&max;__________________If(*pmax<*py)*pmax=*py;If(*pmax<*pz)*pmax=*pz;Printf(“max=%dn”,max);}(16)以下程序的输出结果是____________Intfun(int*x,intn){if(n==0)Returnx[0];Elsereturnx[0]+fun(x+1,n-1);}Main(){inta[]={1,2,3,4,5,6,7};Printf(“%dn”,fun(a,3));n}(17)以下程序的输出结果是______________#includeMain(){char*s1,*s2,m;S1=s2=(char*)malloc(sizeof(char));*s1=15;*s2=20;M=*s1+*s2;Printf(“%dn”,m);}(18)设有说明StructDATE{intyear;intmonth;intday;};请写出一条定义语句,该语句定义d为上述结构体变量,并同时为其成员year、month、day依次赋初值2006、10、1:____________;(19)设有定义:FILE*fw;,请将以下打开文件的语句补充完整,以便可以向文本文件readme.txt的最后续写内容。fw=fopen(“readme.txt”,“________”)2007年4月二级C语言笔试答案选择题1-5:BDACD6-10:CABCA11-15:CDBCA16-20:DCABC21-25:DCABA26-30:ADCDA31-35:BBDDB36-40:DCACA41-45:DADAA46-50:ACBDA填空题1、632、黑盒3、数据库管理系统4、开发5、数据字典6、a=147、0,8、m=4k=4i=5k=59、#&10、911、112、5413、014、i=115、x[i-1]16、*pmax=*px17、1018、4019、structDATEd={2006,10,1}n20、a2007年9月计算机等级考试二级C语言笔试题及答案一、选择题((1)-(10)每题2分,(11)-(50)每题1分.共60分))下列各题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)n(n+1)/2B)nlog2nC)n(n-1)/2D)n/2(8)一棵二叉树中共有70个叶子结点与80个度为1的结点,则该二叉树中的总结点数为A)219B)221C)229D)231(9)下列叙述中正确的是nA)数据库系统是一个独立的系统,不需要操作系统的支持B)数据库技术的根本目标是要解决数据的共享问题C)数据库管理系统就是数据库系统D)以上三种说法都不对(10)下列叙述中正确的是A)为了建立一个关系,首先要构造数据的逻辑关系B)表示关系的二维表中各元组的每一个分量还可以分成若干数据项C)一个关系的属性名表称为关系模式D)一个关系可以包括多个二维表(11)C语言源程序名的后缀是A).exeB).CC).objD).cp(12)可在C程序中用做用户标识符的一组标识符是A)andB)DateC)HiD)case_2007y-m-dDr.TomBigl(13)以下选项中,合法的一组C语言数值常量是A)028B)12.C).177D)0x8A.5e-3OXa234c1.510,000-0xf4.5e0Oabc3.e5(14)以下叙述中正确的是A)C语言程序将从源程序中第一个函数开始执行B)可以在程序中由用户指定任意一个函数作为主函数,程序将从此开始执行C)C语言规定必须用main作为主函数名,程序将从此开始执行,在此结束D)main可作为用户标识符,用以命名任意一个函数作为主函数(15)若在定义语句:inta,b,c,*p=&c;之后,接着执行以下选项中的语句,则能正确执行的语句是A)scanf("%d",a,b,c);B)scanf("%d%d%d",a,b,c);C)scanf("%d",p);D)scanf("%d",&p);(16)以下关于long、int和short类型数据占用内存大小的叙述中正确的是A)均占4个字节B)根据数据的大小来决定所占内存的字节数C)由用户自己定义D)由C语言编译系统决定(17)若变量均已正确定义并赋值,以下合法的C语言赋值语句是A)x=y==5;B)x=n%2.5;C)x+n=I;D)x=5=4+1;(18)有以下程序段intj;floaty;charname[50];scanf("%2d%f%s",&j,&y,name);当执行上述程序段,从键盘上输入555667777abc后,y的值为A)55566.0B)566.0C)7777.0D)566777.0(19)若变量已正确定义,有以下程序段i=0;doprintf("%d,",i);while(i++);printf("%dn",i)其输出结果是A)0,0B)0,1C)1,1D)程序进入无限循环(20)有以下计算公式n√x(x≥0)y=√-x(x<0)若程序前面已在命令中包含math.h文件,不能够正确计算上述公式的程序段是A)if(x>=0)y=sqrt(x);B)y=sqrt(x)elsey=sqrt(-x);if(x<0)y=sqrt(-x);C)if(x>=0)y=sqrt(x);D)y=sqrt(x>=0?x:-x);If(x<0)y=sqrt(-x);(21)设有条件表达式:(EXP)?i++;j--,则以下表达式中(EXP)完全等价的是A)(EXP==0)B)(EXP!=0)C)(EXP==1)D)(EXP!=1)(22)有以下程序#includemain(){inty=9;for(y>0;y--)if(y%3==0)printf("%d",--y);}程序的运行结果是A)741B)963C)852D)875421(23)已有定义:charc;,程序前面已在命令行中包含ctype.h文件,不能用于判断c中的字符是否为大写字母的表达式是A)isupper(c)B)’A’<=c<=’Z’C)’A’<=c&&c<=’Z’D)c<=(‘2’-32)&&(‘a’-32)<=c(24)有以下程序#includemain(){inti,j,m=55;for(i=1;i<=3;i++)for(j=3;j<=i;j++)m=m%j;printf("%dn",m);}程序的运行结果是A)0B)1C)2D)3(25)若函数调用时的实参为变量时,以下关于函数形参和实参的叙述中正确的是A)函数的实参和其对应的形参共占同一存储单元B)形参只是形式上的存在,不占用具体存储单元C)同名的实参和形参占同一存储单元D)函数的形参和实参分别占用不同的存储单元(26)已知字符’A’的ASCⅡ代码值是65,字符变量c1的值是’A’,c2的值是’D’。执行语句printf("%d,%d",c1,c2-2);后,输出结果是A)A,BB)A,68C)65,66D)65,68(27)以下叙述中错误的是A)改变函数形参的值,不会改变对应实参的值nB)函数可以返回地址值C)可以给指针变量赋一个整数作为地址值D)当在程序的开头包含文件stdio.h时,可以给指针变量赋NULL(28)以下正确的字符串常量是A)"\"B)’abc’C)OlympicGamesD)""(29)设有定义:charp[]={’1’,’2’,’3’},*q=p;,以下不能计算出一个char型数据所占字节数的表达式是A)sizeof(p)B)sizeof(char)C)sizeof(*q)D)sizeof(p[0])(30)有以下函数intaaa(char*s){char*t=s;while(*t++);t--;return(t-s);}以下关于aaa函数的功能叙述正确的是A)求字符串s的长度B)比较两个串的大小C)将串s复制到串tD)求字符串s所占字节数(31)若有定义语句:inta[3][6];,按在内存中的存放顺序,a数组的第10个元素是A)a[0][4]B)a[1][3]C)a[0][3]D)a[1][4](32)有以下程序#includevoidfun(char**p){++p;printf("%sn",*p);}main(){char*a[]={"Morning","Afternoon","Evening","Night"};fun(a);}程序的运行结果是A)AfternoonB)fternoonC)MorningD)orning(33)若有定义语句:inta[2][3],*p[3];,则以下语句中正确的是A)p=a;B)p[0]=a;C)p[0]=&a[1][2];D)p[1]=&a;(34)有以下程序#includevoidfun(int*a,intn)/*fun函数的功能是将a所指数组元素从大到小排序*/{intt,i,j;for(i=0;ifor(j=i+1;jif(a}main(){intc[10]={1,2,3,4,5,6,7,8,9,0},i;fun(c+4,6);for(i=0;i<10;i++)printf("%d,",c);printf("n");}程序运行的结果是nA)1,2,3,4,5,6,7,8,9,0,B)0,9,8,7,6,5,1,2,3,4,C)0,9,8,7,6,5,4,3,2,1,D)1,2,3,4,9,8,7,6,5,0,(35)有以下程序#includeintfun(chars[]){intn=0;while(*s<=’9’&&*s>=’0’){n=10*n+*s-’0’;s++;}return(n);}main(){chars[10]={’6’,’1’,’*’,’4’,’*’,’9’,’*’,’0’,’*’};printf("%dn",fun(s));}程序运行的结果是A)9B)61490C)61D)5(36)当用户要求输入的字符串中含有空格时,应使用的输入函数是A)scanf()B)getchar()C)gets()D)getc()(37)以下关于字符串的叙述中正确的是A)C语言中有字符串类型的常量和变量B)两个字符串中的字符个数相同时才能进行字符串大小的比较C)可以用关系运算符对字符串的大小进行比较D)空串一定比空格打头的字符串小(38)有以下程序:#includevoidfun(char*t,char*s){while(*t!=0)t++;while((*t++=*s++)!=0);}main(){charss[10]=”acc”,aa[10]=”bbxxyy”;fun(ss,aa);printf(“%s,%sn”,ss,aa);}程序运行结果是A)accxyy,bbxxyyB)acc,bbxxyyC)accxxyy,bbxxyyD)accbbxxyy,bbxxyy(39)有以下程序#include#includevoidfun(chars[][10],intn){nchart;inti,j;for(i=0;ifor(j=i+1,j/*比较字符串的首字符大小,并交换字符串的首字符*/if(s[0])>s[j][0]{t=s[0];s[0]=s[j][0];s[j][0]=t;}}main(){charss[5][10]={“bcc”,”bbcc”,”xy”,”aaaacc””aabcc”}fun(ss,5);printf(“%s,%sn”,ss[0],ss[4]);}程序运行结果是A)xy,aaaaccB)aaaacc,xyC)xcc,aabccD)acc,xabcc(40)在一个C语言源程序文件中所定义的全局变量,其作用域为:A)所在文件的全部范围B)所在程序的全部范围C)所在函数的全部范围D)由具体定义位置和extern说明来决定范围(41)有以下程序#includeinta=1;intf(intc){staticinta=2;c=c+1;return(a++)+c;}main(){inti,k=0;for(i=0;i<2;i++){inta=3;k+=f(a);}k+=a;printf(“%dn”,k);}程序运行结果是A)14B)15C)16D)17(42)有以下程序#includevoidfun(intn,int*p){intf1,f2;if(n==1||n==2)*p=1;else{fun(n-1,&f1);fun(n-2,&f2);*p=f1+f2;}}main(){ints;nfun(3,&s);printf("%dn",s);}程序的运行结果是A)2B)3C)4D)5(43)若程序中有宏定义行:#defineN100则以下叙述中正确的是A)宏定义行中定义了标识符N的值为整数100B)在编译程序对C源程序进行预处理时用100替换标识符NC)对C源程序进行编译时用100替换标识符ND)在运行时用100替换标识符N(44)以下关于typedef的叙述错误的是A)用typedef可以增加新类型B)typedef只是将已存在的类型用一个新的名字来代表C)用typedef可以为各种类型说明一个新名,但不能用来为变量说明一个新名D)用typedef为类型说明一个新名,通常可以增加程序的可读性(45)有以下程序#includestructtt{intx;structtt*y;}*p;structtta[4]={20,a+1,15,a+2,30,a+3,17,a};main(){inti;p=a;for(i=1;i<=2;i++){printf("%d,",p->x);p=p->y;}}程序的运行结果是A)20,30,B)30,17C)15,30,D)20,15,(46)有以下程序#include#includetypedefstruct{charname[9];charsex;floatscore[2];}STU;STUf(STUa){STUb={"Zhao",'m',85.0,90.0};inti;strcpy(a.name,b.name);a.sex=b.sex;for(i=0;i<2;i++)a.score=b.score;returna;}main(){STUc={"Qian",'f',95.0,92.0},d;d=f(c);printf("%s,%c,%2.0f,%2.0fn",d.name,d.sex,d.score[0],d.score[1]);}程序的运行结果是A)Qian,f,95,92B)Qian,m,85,90C)Zhao,m,85,90D)Zhao,f,95,92(47)设有以下定义nuniondata{intd1;floatd2;}demo;则下面叙述中错误的是A)变量demo与成员d2所占的内存字节数相同B)变量demo中各成员的地址相同C)变量demo和各成员的地址相同D)若给demo.d1赋99后,demo.d2中的值是99.0(48)有以下程序#includemain(){inta=1,b=2,c=3,x;x=(a^b)&c;printf("%dn",x);}程序的运行结果是A)0B)1C)2D)3(49)读取二进制文件的函数调用形式为:fread(buffer,size,count,fp);,其中buffer代表的是A)一个文件指针,指向待读取的文件B)一个整型变量,代表待读取的数据的字节数C)一个内存块的首地址,代表读入数据存放的地址D)一个内存块的字节数(50)有以下程序#includemain(){FILE*fp;inta[10]={1,2,3,0,0},i;fp=fopen("d2.dat,"wb");fwrite(a,sizeof(int),5,fp);fwrite(a,sizeof(int),5,fp);fclose(fp);fp=fopen("d2.dat","rb");fread(a,sizeof(int),10,fp);fclose(fp);for(i=0;i<10;i++)printf("%d",a);}程序的运行结果是A)1,2,3,0,0,0,0,0,0,0,B)1,2,3,1,2,3,0,0,0,0,C)123,0,0,0,0,123,0,0,0,0,D)1,2,3,0,0,1,2,3,0,0,二、填空题(每空2分,共40分)请将每一个空的正确答案写在答题卡[1]至[20]序号的横线上,答在试卷上不得分.(1)软件需求规格说明书应具有完整性、无歧义性、正确性、可验证性、可修改性等特性,其中最重要的_[1]_______.(2)在两种基本测试方法中,_[2]_______测试的原则之一是保证所测模块中每一个独立路径至少要执行一次.(3)线性表的存储结构主要分为顺序存储结构和链式存储结构.队列是一种特殊的线性表,n循环队列是队列的_[3]_______存储结构.(4)对下列二叉树进行中序遍历的结果为_[4]_______FCEHGBDPA(5)在E-R图中距形表示_[5]_______(6)执行以下程序时输入1234567,则输出结果是_[6]_______.#includemain(){inta=1,b;scanf("%2d%2d",&a&b);printf("%d%dn",a,b);}(7)以下程序的功能是:输出a、b、c三个变量中的最小值.请填空。#includemain(){inta,b,c,t1,t2;scanf("%d%d%d",&a,&b,&c);t1=at2=cprintf("%dn",t2);}(8)以下程序的输出结果是_[9]_______.#includemain(){intn=12345,d;while(n!=0){d=n%10;printf("%d",d);n/=10;}}(9)有以下程序段,且变量已正确定义和赋值for(s=1.0,k=1;k<=n;k++)s=s+1.0/(k*(k+1));printf("s=%fnn",s);请填空,使下面程序段的功能为完全相同s=1.0;k=1;while(_[10]_______){s=s+1.0/(k*(k+1));_[11]_______;}printf("s=%fnn",s);(10)以下程序的输出结果是_[12]_______.#includemain(){inti;for(i='a';i<'f';i++,i++)printf("%c",i-'a'+'A');nprintf("n");}(11)以下程序的输出结果是_[13]_______.#include#includechar*fun(char*t){char*p=t;return(p+strlen(t)/2);}main(){char*str="abcdefgh";str=fun(str);puts(str);}(12)以下程序中函数f的功能是在数组x的n个数(假定n个数互不相同)中找出最大最小数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换.请填空.#includeviodf(intx[],intn){intp0,p1,i,j,t,m;i=j=x[0];p0=p1=0;for(m=0;m{if(x[m]>i){i=x[m];p0=m;}elseif(x[m]}t=x[p0];x[p0]=x[n-1];x[n-1]=t;t=x[p1];x[p1]=_[14]_______;_[15]_______=t;}main(){inta[10],u;for(u=0;u<10;u++)scanf("%d",&a);f(a,10);for(u=0;u<10;u++)printf("%d",a);printf("n");}(13)以下程序统计从终端输入的字符中大写字母的个数,num[0]中统计字母A的个数,num[1]中统计字母B的个数,其它依次类推.用#号结束输入,请填空.#include#includemain(){intnum[26]={0},i;charc;while((_[16]_______)!='#')if(isupper(c))num[c-‘A’]+=_[17]_______;for(i=0;i<26;i++)Printf("%c:%dn",i+'A',num);}(14)执行以下程序的输出结果是_[18]_______.n#includemain(){inti,n[4]={1};for(i=1;i<=3;i++){n=n[i-1]*2+1;printf("%d",n);}}(15)以下程序的输出结果是_[19]_______.#include#defineM5#defineNM+Mmain(){intk;k=N*N*5;printf("%dn",k);}(16)函数main()的功能是:在带头结点的单链表中查找数据域中值最小的结点.请填空#includestructnode{intdata;structnode*next;};intmin(structnode*first)/*指针first为链表头指针*/{strctnode*p;intm;p=first->next;m=p->data;p=p->next;for(;p!=NULL;p=_[20]_______)if(p->datadata;returnm;一、选择题1~10DBCADCCABD11~20BABCCDABBB21~30BCBBDCCDAA31~40BDCDCCDDDD41~50AABADCDDCD二、选择题1.无歧义性2.白盒3.顺序4.ACBDFEHGP5.实体6.12347.a:bc:t18.543219.k<=nk++10.ACE11.efgh12.x[0]x[0]13.c=getchar()114.371515.5516.p->next2008年4月全国计算机等级考试二级笔试试卷nC语言程序设计(考试时间90分钟,满分100分)一、选择题(共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)对长度为n的线性表排序,在最坏情况下,比较次数不是n(n-1)/2的排序方法是A)快速排序B)冒泡排序C)直接插入排序D)堆排序(7)下列关于栈的叙述正确的是A)栈按“先进先出”组织数据B)栈按“先进后出”组织数据C)只能在栈底插入数据D)不能删除数据(8)在数据库设计中,将E-R图转换成关系数据模型的过程属于[C]A)需求分析阶段B)概念设计阶段C)逻辑设计阶段D)物理设计阶段(9)有三个关系R、S和T如下:TBCDa0k1RSBCDa0k1b1n1BCDf3h2a0k1n2x1n有关系R和S通过运算得到关系T,则所使用的运算为A)并B)自然连接C)笛卡尔积D)交(10)设有表示学生选课的三张表,学生S(学号,姓名,性别,年龄,身份证号),课程C(课号,课名),选课SC(学号,课号,成绩),则表SC的关键字(键或码)为A)课号,成绩B)学号,成绩C)学号,课号D)学号,姓名,成绩(11)以下叙述中正确的是A)C程序中的注释只能出现在程序的开始位置和语句的后面B)C程序书写格式严格,要求一行内只能写一个语句C)C程序书写格式自由,一个语句可以写在多行上D)用C语言编写的程序只能放在一个程序文件中(12)以下选项中不合法的标识符是A)printB)FORC)&aD)_00(13)以下选项中不属于字符常量的是A)'C'B)"C"C)'xCC0'D)'72'(14)设变量已正确定义并赋值,以下正确的表达式是A)x=y*5=x+zB)int(15.8%5)C)x=y+z+5,++yD)x=25%5.0(15)以下定义语句中正确的是A)inta=b=0;B)charA=65+1,b='b';C)floata=1,*b=&a,*c=&b;D)doublea=0.0,b=1.1;(16)有以下程序段charch;intk;ch='a';k=12;printf("%c,%d,",ch,ch,k);printf("k=%dn",k);已知字符a的ASCll十进制代码为97,则执行上述程序段后输出结果是A)因变量类型与格式描述符的类型不匹配输出无定值B)输出项与格式描述符个数不符,输出为零值或不定值C)a,97,12k=12D)a,97,k=12(17)已知字母A的ASCⅡ代码值为65,若变量kk为char型,以下不能正确判断出kk中的值为大写字母的表达式是A)kk>='A'&&kk<='Z'B)!(kk>='A'‖kk<='Z')C)(kk+32)>='a'&&(kk+32)<='z'D)isalpha(kk)&&(kk<91)(18)当变量c的值不为2、4、6时,值也为“真”的表达式是A)(c==2)‖(c==4)‖(c==6)B)(c>=2&&c<=6)‖(c!=3)‖(c!=5)C)(c>=2&&c<=6)&&!(c%2)D)(c>=2&&c<=6)&&(c%2!=1)(19)若变量已正确定义,有以下程序段inta=3,b=5,c=7;if(a>b)a=b;c=a;nif(c!=a)c=b;printf("%d,%d,%dn",a,b,c);其输出结果是A)程序段有语法错B)3,5,3C)3,5,5D)3,5,7(20)有以下程序#includemain(){intx=1,y=0,a=0,b=0;switch(x){case1:switch(y){case0:a++;break;case1:b++;break;}case2:a++;b++;break;case3:a++;b++;}printf(“a=%d,b=%dn”,a,b);}程序的运行结果是A)a=1,b=0B)a=2,b=2C)a=1,b=1D)a=2,b=1(21)有以下程序#includemain(){intx=8;for(;x>0;x--){if(x%3){printf(“%d,”,x--);continue;}printf(“%d,”,--x);}}程序的运行结果是A)7,4,2B)8,7,5,2C)9,7,6,4D)8,5,4,2(22)以下不构成无限循环的语句或者语句组是A)n=0;B)n=0;do{++n;}while(n<=0);while(1){n++;}C)n=10;D)for(n=0,i=1;;i++)n+=i;while(n);{n--;}(23)有以下程序#includemain()n{inta[]={1,2,3,4},y,*p=&a[3];--p;y=*p;printf(“y=%dn”,y);}程序的运行结果是A)y=0B)y=1C)y=2D)y=3(24)以下错误的定义语句是A)intx[][3]={{0},{1},{1,2,3}};B)intx[4][3]={{1,2,3},{1,2,3},{1,2,3},{1,2,3}};C)intx[4][]={{1,2,3},{1,2,3},{1,2,3},{1,2,3}};D)intx[][3]={1,2,3,4};(25)设有如下程序段chars[20]=“Bejing”,*p;p=s;则执行p=s;语句后,以下叙述正确的是A)可以用*p表示s[0]B)s数组中元素的个数和p所指字符串长度相等C)s和p都是指针变量D)数组s中的内容和指针变量p中的内容相等(26)若有定义:inta[2][3];,以下选项中对a数组元素正确引用的是A)a[2][!1]B)a[2][3]C)a[0][3]D)a[1>2][!1](27)有定义语句:chars[10];,若要从终端给s输入5个字符,错误的输入语句是A)gets(&s[0]);B)scanf(“%s”,s+1);C)gets(s);D)scanf(“%s”,s[1]);(28)以下叙述中错误的是A)在程序中凡是以“#”开始的语句行都是预处理命令行B)预处理命令行的最后不能以分号表示结束C)#defineMAX是合法的宏定义命令行D)C程序对预处理命令行的处理是在程序执行的过程中进行的(29)以下结构体类型说明和变量定义中正确的是A)typedefstructB)structREC;{intn;charc;}REC;{intn;charc;};RECt1,t2;RECt1,t2;C)typedefstructREC;D)struct{intn=0;charc=’A’;}t1,t2;{intn;charc;}RECt1,t2;(30)以下叙述中错误的是A)gets函数用于从终端读入字符串B)getchar函数用于从磁盘文件读入字符C)fputs函数用于把字符串输出到文件D)fwrite函数用于以二进制形式输出数据到文件(31)有以下程序#includemain()n{ints[12]={1,2,3,4,4,3,2,1,1,1,2,3},c[5]={0},i;for(i=0;i<12;i++)c[s[i]]++;for(i=1;i<5;i++)printf(“%d”,c[i]);printf(“n”);}程序的运行结果是A)1234B)2344C)4332D)1123(32)有以下程序#includevoidfun(int*s,intnl,intn2){inti,j,t;i=nl;j=n2;while(i#includevoidfun(char*s[],intn){char*t;inti,j;for(i=0;istrlen(s[j])){t=s[i];s[i]=s[j];s[j]=t;}}main(){char*ss[]={“bcc”,”bbcc”,”xy”,”aaaacc”,”aabcc”};fun(ss,5);printf(“%s,%sn”,ss[0],ss[4]);}程序的运行结果是A)xy,aaaaccB)aaaacc,xyC)bcc,aabccD)aabcc,bcc(34)有以下程序#includeintf(intx){inty;if(x==0||x==1)return(3);ny=x*x-f(x-2);returny;}main(){intz;z=f(3);printf(“%dn”,z);}程序的运行结果是A)0B)9C)6D)8(35)有以下程序#includevoidfun(char*a,char*b){while(*a==’*’)a++;while(*b=*a){b++;a++;}}main(){char*s=”****a*b****”,t[80];fun(s,t);puts(t);}程序的运行结果是A)*****a*bB)a*bC)a*b****D)ab(36)有以程序#include#includetypedefstruct{charname[9];charsex;floatscore[2];}STU;voidf(STUa){STUb={“Zhao”,’m’,85.0,90.0};inti;strcpy(a.name,b.name);a.sex=b.sex;for(i=0;i<2;i++)a.score[i]=b.score[i];}main(){STUc={“Qian”,’p’,95.0,92.0};f(c);printf(“%s,%c,%2.0f,%2.0fn”,c.name,c.sex,c.score[0],c.score[1]);}程序的运行结果是A)Qian,f,95,92B)Qian,m,85,90C)Zhao,f,95,92D)Zhao,m,85,90(37)有以下程序#includemain()n{FILE*fp;inta[10]={1,2,3},i,n;fp=fopen(“dl.dat”,”w”);for(i=0;i<3;i++)fprintf(fp,”%d”,a[i]);fprintf(fp,”n”);fclose(fp);fp=fopen(“dl.dat”,”r”);fscanf(fp,”%d”,&n);fclose(fp);printf(“%dn”,n);}程序的运行结果是A)12300B)123C)1D)321(38)变量a中的数据用二进制表示的形式是01011101,变量b中的数据用二进制表示的形式是11110000。若要求将a的高4位取反,低4位不变,所要执行的运算是A)a^bB)a|bC)a&bD)a<<4(39)在C语言中,只有在使用时才占用内存单元的变量,其存储类型是A)auto和registerB)extern和registerC)auto和staticD)static和register(40)设有定义语句int(*f)(int);,则以下叙述正确的是A)f是基类型为int的指针变量B)f是指向函数的指针变量,该函数具有一个int类型的形参C)f是指向int类型一维数组的指针变量D)f是函数名,该函数的返回值是基类型为int类型的地址二、填空题(每空2分,共30分)请将每一个空的正确答案些在答题卡【1】至【15】序号的横线上,答在试卷上不得分。(1)测试用例包括输入值集和【1】值集。(2)深度为5的满二叉树有【2】个叶子结点。(3)设某循环队列的容量为50,头指针front=5(指向队头元素的前一位置),尾指针rear=29(指向队尾元素),则该循环队列中共有【3】个元素。(4)在关系数据库中,用来表示实体之间联系的是【4】。(5)在数据库管理系统提供的数据定义语言、数据操纵语言和数据控制语言中,【5】负责数据的模式定义与数据的物理存取构建。(6)已有定义:charc=’‘;inta=1,b;(此处c的初值为空格字符),执行b=!c&&a;后b的值为【6】。(7)设变量已正确定义为整型,则表达式n=i=2,++i,i++的值为【7】。(8)若有定义:intk;,以下程序段的输出结果是【8】。for(k=2;k<6;k++,k++)printf(“##%d”,k);(9)以下程序段的定义语句中,x[1]的初值是【9】,程序运行后输出的内容是【10】。#includemain(){intx[]={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16},*p[4],i;for(i=0;i<4;i++){p[i]=&x[2*i+1];nprintf(“%d”,p[i][0]);}printf(“n”);}(10)以下程序的输出结果是【11】。#includevoidswap(int*a,int*b){int*t;t=a;a=b;b=t;}main(){inti=3,j=5,*p=&i,*q=&j;swap(p,q);printf(“%d%dn”,*p,*q);}(11)以下程序的输出结果是【12】。#includemain(){inta[5]={2,4,6,8,10},*p;p=a;p++;printf(“%d”,*p);}(12)以下程序的输出结果是【13】。#includevoidfun(intx){if(x/2>0)fun(x/2);printf(“%d”,x);}main(){fun(3);printf(“n”);}(13)以下程序中函数fun的功能是:统计person所指结构体数组中所有性别(sex)为M的记录的个数,存入变量n中,并做为函数值返回。请填空:#include#defineN3typedefstruct{intnum;charnam[10];charsex;}SS;intfun(SSperson[]){inti,n=0;for(i=0;imain(){FILE*fp;charch;fp=fopen(【15】);ch=fgetc(fp);whlie(!feof(fp)){putchar(ch);ch=fgetc(fp);}putchar(‘n’);fclose(fp);}参考答案:一、选择题1-10:CABBADBCDC11-20:CCBCBDBBBD21-30:DADCADDDAB31-40:CCACCABAAB二、填空题:1、输出2、163、244、关系5、数据定义语言6、07、38、##2##49、210、246811、3512、413、1314、person[i].sex15、“filea.dat”,”r”2008年9月全国计算机等级考试二级笔试试卷C语言程序设计n(考试时间90分钟,满分100分)一、选择题    下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的。请将正确选项涂写在答题卡相应位置上,答在试卷上不得分。(1)一个栈的初始状态为空。现将元素1、2、3、4、5、A、B、C、D、E依次入栈,然后再依次出栈,则元素出栈的顺序是A)12345ABCDE                         B)EDCBA54321C)ABCDE12345                         D)54321EDCBA(2)下列叙述中正确的是A)循环队列有队头和队尾两个指针,因此,循环队列是非线性结构B)在循环队列中,只需要队头指针就能反应队列中元素的动态变化情况C)在循环队列中,只需要队尾指针就能反应队列中元素的动态变化情况D)循环队列中元素的个数是由队头和队尾指针共同决定(3)在长度为n的有序线性表中进行二分查找,最坏情况下需要比较的次数是A)O(N)        B)O(n2)       C)O(log2n)        D)O(n log2n)(4)下列叙述中正确的是A)顺序存储结构的存储一定是连续的,链式存储结构的存储空间不一定是连续的B)顺序存储结构只针对线性结构,链式存储结构只针对非线性结构C)顺序存储结构能存储有序表,链式存储结构不能存储有序表D)链式存储结构比顺序存储结构节省存储空间(5)数据流图中带有箭头的线段表示的是A)控制流        B)事件驱动       C)模块调用        D)数据流(6)在软件开发中,需求分析阶段可以使用的工具是A)N-S图  B)DFD图  C)PAD图  D)程序流程图(7)在面向对象方法中,不属于“对象”基本特点的是A)一致性  B)分类性  C)多态性  D)标识唯一性(8)一间宿舍可住多个学生,则实体宿舍和学生之间的联系是A)一对一  B)一对多  C)多对一  D)多对多(9)在数据管理技术发展的三个阶段中,数据共享最好的是A)人工管理阶段    B)文件系统阶段  C)数据库系统阶段  D)三个阶段相同(10)有三个关系R、S和T如下:A B Cm 1 3R                    S                                    TA Bm 1n 2B C1 33 5 由关系R和S通过运算得到关系T,则所使用的运算为A)笛卡尔积        B)交        C)并        D)自然连接(11)以下叙述中正确的是A)C程序的基本组成单位是语句           B)C程序中每一行只能写一条语句     C)简单C语句必须以分号结束             D)C语句必须在一行内写完(12)计算机能直接执行的程序是A)源程序       B)目标程序       C)汇编程序        D)可执行程序(13)以下选项中不能作为C语言合法常量的是A)’cd’        B)0.1e+6       C)”a”        D)”11”(14)以下选项中正确的定义语句是A)double a;b;       B)double a=b=7;     C)double a=7,b=7;       D)double ,a,b;(15) 以下不能正确表示代数式 的C语言表达式是A)2*a*b/c/d      B)a*b/c/d*2        C)a/c/d*b*2         D)2*a*b/c*d(16)C源程序中不能表示的数制是    A)二进制        B) 八进制        C) 十进制        D) 十六进制 (17) 若有表达式(w)?(--x):(++y),则其中与w等价的表达式是    A) w= =1        B) w= =0        C)w!=1          D) w!=0 (18) 执行以下程序段后,w的值为    int  w=’A’,x=14,y=15;     w=((x||y)&&(w<’a’));   A)-1           B)NULL         C)1           D) 0(19)若变量已正确定义为int型,要通过语句scanf(“%d,%d,%d ”,&a,&b,&c);给a赋值1,给b赋值2, 给c赋值3, 以下输入形式中错误的是(u代表一个空格符)   A)uuu1,2,3<回车>                B)1u2u3<回车>   C)1,uuu2, uuu3<回车>             D)1,2,3<回车>(20) 有以下程序段       int    a,b,c;       a=10; b=50; c=30;       if(a>b)a=b,b=c;c=a;       printf(“a=%d b=%d c=%d n”,a,b,c);程序的输出结果是A) a=10 b=50 c=10                 B) a=10 b=50 c=30C) a=10 b=30 c=10                 D) a=50 b=30 c=50(21) 若有定义语句:int  m[]={5,4,3,2,1},i=4;,则下面对m数组元素的引用中错误的是     A) m[--i]          B)m[2*2]         C)m[m[0]]         D)m[mn](22)下面的函数调用语句中func函数的实参个数是       func(f2(v1,v2),(v3,v4,v5),(v6,max(v7,v8))); A)3          B) 4          C)5          D)8(23)若有定义语句:double  x[5]={1.0,2.0,3.0,4.0,5.0},*p=x;则错误引用x数组元素的是     A)*p         B)x[5]        C)*(p+1)         D)*x(24) 若有定义语句:char s[10]= “1234567 ”;,则strlen(s)的值是     A)7     B)8      C)9      D)10(25)以下叙述中错误的是     A) 用户定义的函数中可以没有return语句     B)用户定义的函数中可以有多个return语句,以便可以调用一次返回多个函数值     C)用户定义的函数中若没有return语句,则应当定义函数为void类型     D)函数的return语句中可以没有表达式(26)以下关于宏的叙述中正确的是     A)宏名必须用大写字母表示      B)宏定义必须位于源程序中所有语句之前     C)宏替换没有数据类型限制      D)宏调用比函数调用耗费时间(27)有以下程序#include main() { int i,j; for(i=3;i>=1;i--)  {  for(j=1;j<=2;j++)   printf("%d",i+j);    printf("n ")  }} 程序的运行结果是A) 2 3 4        B) 4 3 2       C) 2 3          D) 4 53 4 5            5 4 3           3 4              3 4                               4 5              2 3(28) 有以下程序#include main(){   int   x=1,y=2,z=3; if(x>y) if(ymain(){  int   i=5;   do   {  if(i%3==1)        if(i%5==2)         {  printf(“*%d”,i);  break;  }      i++;   }   while(i!=0);   printf(“n”);}程序的运行结果是A) *7          B)*3*5           C)*5           D)*2*6(30)有以下程序#include  int fun(int  a,int   b){ if(b==0)  return a; else     return(fun(--a,--b));}main(){  printf("%dn", fun(4,2));}程序的运行结果是A) 1            B)2            C)3           D)4 (31) 有以下程序#include  #include  int  fun(int   n){  int  *p;    p=(int*)malloc(sizeof(int));   *p=n;   return  *p;}main(){   int  a;   a = fun(10);    printf("%dn",a+fun(10));}程序的运行结果是A)0          B)10             C)20             D)出错(32)有以下程序#include  void  fun( int  a,   int  b){  int   t;   t=a;  a=b;  b=t;}main(){  int  c[10]={1,2,3,4,5,6,7,8,9,0}, i;   for(i=0;i<10;i+=2)  fun(c, c[i+1]);   for(i=0;i<10;i++)  printf("%d," ,c);   printf("n");}程序的运行结果是A)1,2,3,4,5,6,7,8,9,0               B)2,1,4,3,6,5,8,7,0,9C)0,9,8,7,6,5,4,3,2,1               D)0,1,2,3,4,5,6,7,8,9(33) 有以下程序#include  struct   st{  int  x, y;} data[2]={1,10,2,20};main(){   struct  st  *p=data;    printf("%d,",p->y);   printf("%dn",(++p)->x);}程序的运行结果是A)10,1        B)20,1       C)10,2       D)20,2(34) 有以下程序#include  void fun(int  a[], int  n)  {  int   i,t;   for(i=0;i#define  N   4void fun(int  a[][N], int  b[]){  int  i;   for(i=0;iint fun(int  (*s)[4],int n, int k){ int   m,i; m=s[0][k]; for(i=1;im)m= s[k]; return  m;}main() { int  a[4][4]={{1,2,3,4},{11,12,13,14},{21,22,23,24},{31,32,33,34}}; printf("%dn",fun(a,4,0));}程序的运行结果是 A)4          B)34          C)31            D)32(37) 有以下程序#include  main(){ struct STU {  char  name[9]; char  sex;  double  score[2];}; struct STU  a={"Zhao",'m',85.0,90.0},b={"Qian",'f',95.0,92.0}; b=a; printf("%s,%c,%2.0f,%2.0fn", b.name, b.sex, b.score[0], b.score[1]);}程序的运行结果是A) Qian,f,95,92    B) Qian,m,85,90    C) Zhao,f,95,92    D) Zhao,m,85,90(38) 假定已建立以下链表结构,且指针p和q已指向如图所示的结点:head  a  b  c                data  next                  p             q 则以下选项中可将q所指向结点从链表中删除并释放该结点的语句组是A)(*p).next=(*q).next;  free(p);        B)p=q->next;  free(q);C) p=q;  free(q);                    D)p->next=q->next;  free(q);(39) 有以下程序#include  main(){  char  a=4;   printf(“%dn”,a=a<<1);}程序的运行结果是A) 40         B) 16        C) 8         D) 4(40) 有以下程序#include  main(){ FILE    *pf; char  *s1="China", *s2="Beijing"; pf=fopen("abc.dat","wb+"); fwrite(s2,7,1,pf); rewind(pf);          /*文件位置指针回到文件开头*/ fwrite(s1,5,1,pf); fclose(pf);}以上程序执行后abc.dat文件的内容是     A) China      B) Chinang      C) ChinaBeijing      D) BeijingChina二、填空题 (每空2分,共30分)请将每一个空的正确答案写在答题卡【1】至【15】序号的横线上,答在试卷上不得分。(1)对下列二叉树进行中序遍历的结果是  【1】   。 (2)按照软件测试的一般步骤,集成测试应在  【2】  测试之后进行。(3)软件工程三要素包括方法、工具和过程,其中,  【3】  支持软件开发的各个环节的控制和管理。(4)数据库设计包括概念设计、  【4】  和物理设计。(5)在二维表中,元组的  【5】  不能再分成更小的数据项。(6)设变量a和b已正确定义并赋初值。请写出与a-=a+b等价的赋值表达式 【6】 。(7)若整型变量a和b中的值分别为7和9,要求按以下格式输出a和b的值:     a=7     b=9请完成输出语句:printf(  “  【7】   “,a,b);(8)以下程序的输出结果是  【8】  。#includemain(){ int i,j,sum; for(i=3;i>=1;i--) {  sum=0;  for(j=1;j<=i;j++)   sum+=i*j; } printf("%dn",sum);}(9)以下程序的输出结果是  【9】  。#includemain(){ int j,a[]={1,3,5,7,9,11,13,15},*p=a+5;   for(j=3;j;j--)     {  switch(j)    {      case 1:   case 2:printf(“%d”,*p++); break;   case 3:printf(“%d”,*(--p));    }    }}(10)以下程序的输出结果是  【10】  。#include#define   N   5int fun(int *s,int a ,int n){ int j; *s=a;  j=n; while(a!=s[j])  j--; return j;}main(){ int s[N+1];   int k; for(k=1;k<=N;k++)  s[k]=k+1; printf("%dn",fun(s,4,N));}(11)以下程序的输出结果是  【11】  。#include int fun(int x){ static int t=0; return(t+=x);}main(){ int s,i; for(i=1;i<=5;i++)  s=fun(i); printf("%dn",s);}(12)以下程序按下面指定的数据给x数组的下三角置数,并按如下形式输出,请填空。             43     72      6     91      5     8    10#include main(){ int x[4][4],n=0,i,j; for(j=0;j<4;j++)  for(i=3;i>=j;  【12】  ) {n++;x[j]=  【13】  } for(i=0;i<4;i++) { for(j=0;j<=i;j++)   printf("=",x[j]);  printf("n"); }}(13)以下程序的功能是:通过函数func输入字符并统计输入字符的个数。输入时用字符@作为输入结束标志。请填空。#include long   【14】        /*  函数说明语句  */main(){ long n; n=func();  printf("n=%ldn",n);}long func(){ long m; for(m=0;getchar()!='@';  【15】  ); return m;}2008年9月全国计算机等级考试二级C语言笔试试卷(参考答案)一、选择题 1-10  BDCAD  BABCD11-20  CDACD  ADCBA21-30  CABAB  CDDAB31-40  CACDB  CDDCB二、填空题【1】 DBXEAYFZC 【2】 单元 【3】 过程 【4】 逻辑设计 【5】 分量 【6】 a=a-(a+b) 【7】 a=%dnb=%d 【8】 1 【9】 9911 【10】 3 【11】 15 【12】 i-- 【13】 n 【14】 func() 【15】 m++ n2009年3月全国计算机等级考试二级笔试试卷C语言程序设计(考试时间90分钟,满分100分)选择题(1)下列叙述中正确的是       A) 栈是“先进先出”的线性表B) 队列是“先进先出”的线性表C) 循环队列是非线性结构D) 有序性表既可以采用顺序存储结构,也可以采用链式存储结构(2)支持子程序调用的数据结构是                            A) 栈            B) 树            C) 队列       D)二叉树(3)某二叉树有5个度为2的结点,则该二叉树中的叶子结点数是     A)10            B)8              C)6           D)4(4)下列排序方法中,最坏情况下比较次数最少的是 A)冒泡排序   B)简单选择排序   C)直接插入排序   D)堆排序(5)软件按功能可以分为:应用软件、系统软件和支撑软件(或工具软件)。下面属于应用软件的是 A)编译软件   B)操作系统  C)教务管理系统  D)汇编程序(6)下面叙述中错误的是A)软件测试的目的是发现错误并改正错误B)对被调试的程序进行“错误定位”是程序调试的必要步骤C)程序调试通常也称为DebugD)软件测试应严格执行测试计划,排除测试的随意性(7)耦合性和内聚性是对模块独立性度量的两个标准。下列叙述中正确的是 nA)提高耦合性降低内聚性有利于提高模块的独立性B)降低耦合性提高内聚性有利于提高模块的独立性C)耦合性是指一个模块内部各个元素间彼此结合的紧密程度D)内聚性是指模块间互相连接的紧密程度(8)数据库应用系统中的核心问题是A)数据库设计      B)数据库系统设计C)数据库维护       D) 数据库管理员培训(9)有两个关系R,S如下:R                     SA B C  A Ba 3 2  a 3b 0 1  b 0c 2 1  c 2 由关系R通过运算得到关系S,则所使用的运算为A) 选择        B)投影        C) 插入        D)连接(10)将E-R图转换为关系模式时,实体和联系都可以表示为A) 属性        B)键          C) 关系         D) 域(11)以下选项中合法的标识符是 A) 1-1        B)1—1       C)-11        D)1--(12)若函数中有定义语句:int k;,则 A)系统将自动给k赋初值0    B)这时k中值无定义 C)系统将自动给k赋初值-1    D)这时k中无任何值(13)以下选项中,能用作数据常量的是      A)o115   B) 0118  C)1.5e1.5    D) 115L(14)设有定义:int x=2; ,以下表达式中,值不为6的是A) x*=x+1     B) x++,2*x    C)x*=(1+x)    D)2*x,x+=2(15)程序段:int x=12;  double y=3.141593; printf(“%d%8.6f”,x,y);的输出结果是A)123.141593   B)12   3.141593   C)12,3.141593    D)123.141593(16)若有定义语句:double x,y,*px,*py,执行了px=&x, py=&y;之后,正确的输入语句是    A)scanf(“%f%f”,x,y);                   B) scanf(“%f%f”,&x,&y);    C) scanf(“%lf%le”,px,py);               D) scanf(“%lf%lf”,x,y);(17)以下是if语句的基本形式:if (表达式) 语句其中“表达式”A)必须是逻辑表达式                    B)必须是关系表达式C)必须是逻辑表达式或关系表达式        D)可以是任意合法的表达式(18)有以下程序#include main(){int x;scanf(“%d”,&x);if(x<=3); elseif(x!=10)  printf(“%dn”,x);}程序运行时,输入的值在哪个范围才会有输出结果A)不等于10的整数         nB)大于3且不等于10的整数C) 大于3或等于10的整数  D)小于3的整数(19)有以下程序#includeMain(){  int a=1,b=2,c=3,d=0;if(a= =1 &&b++= =2)if(b!=2 || c--!=3)  printf(“%d,%d,%dn”,a,b,c);else printf(“%d,%d,%dn”,a,b,c);else printf(“%d,%d,%dn”,a,b,c);}程序运行后的输出结果是A)1,2,3                 B)1,3,2          C)1,3,3              D)3,2,1(20)以下程序中的变量已正确定义for(i=0;i<4;i++,i++for(k=1;k<3;k++);printf(*”);程序段的输出结果是A)********         B)****         C)**          D)*(21)有以下程序#includemain(){char  *s=(“ABC);do{printf(“%d”,*s%10);s++;}while(*s);}注意,字母A的ASCII码值为65。程序运行后的输出结果是A)5670             B)656667            C)567             D)ABC(22)设变量已正确定义,以下不能统计出一行中输入字符个数(不包含回车符)的程序段是A)n=0;while((ch=getchar())!=’n’)n++;   B) n=0;while(getchar()!=’n’)n++;C)for(n=0; getchar()!=’n’;n++);           D)n=0;for(ch=getchar();ch!=’n’;n++);(23)有以下程序#includemain(){ int a1,a2;char c1,c2;scanf(“%d%c%d%c”,&a1,&c1,&a2,&c2);printf(“%d,%c,%d,%c”,&1,c1,a2,c2);}若想通过键盘输入,使得a1的值为12,a2的是为34,c1的值为字符a,c2的值为字符b,程序输出结果是:12,a,34,b,则正确的输入格式是(以下  代表空格,代表回车)A)12a34b              B)12   a    34   bC)12,a,34,b            D)12    a34    nb(24)有以下程序#includeint f(int x,int y){return()y-x)*x);}main(){int a=3,b=4,c=5,d;d=f(f(a,b),f(a,c));printf(“%dn”,d);}程序运行后的输出结果是A)10    B)9     C)8      D)7(25)有以下程序#includevoid fun(char  *s){while(*s)  { if(*s%2==0)  printf(“%c”,*s);s++;  }}main(){ char  a[]={“good”}; fun(a);printf(“n”);}注意:字母a的ASCⅡ码值为97,程序运行后的输出结果是A)d      B)go    C)god   D)good(26)有以下程序#include void fun( int *a,int *b){int *c;c=a;a=b;b=c;}main(){int x=3,y-5,*P=&x,*q=&y; fun(p,q);printf(“%d,%d,”,*p,*q);fun(&x,&y);printf(“%d,%dn”,*p,*q);}程序运行后的输出结果是A)3,5,5,3   B)3,5,3,5   C)5,3,3,5   D)5,3,5,3(27)有以下程序#include viod f(int *p,int *q );main(){ int m=1,n=2,*r=&m;  f(r,&n);printf(“%d,%d”n,m,n);}void f(int *p,int *q){p=p+1;*q=*q+1;}程序运行后输出的结果是A)1,3    B)2,3   C)1,4   D)1,2(28)以下函数按每行8个输出数组中的数据void fun( int *w,int n){ int i;  for(i=0;imain(){ char *a[ ]={“abcd”,”ef”,”gh”,”ijk”};int I;    for (i=0;i<4;i++)  printf(“%c”,*a);}程序运行后输出的结果是A)aegi     B)dfhk    C)abcd    D)abcdefghijk(32)以下选项中正确的语句组是A)char s[];s=”BOOK!”;       B) char *s;s={”BOOK!”};C)char s[10];s=”BOOK!”;    D) char *s;s=”BOOK!”;(33)有以下程序#include int fun{int x,int y}{ if(x==y) return(x);  else nreturen((x+y)/2)}main(){ int a=4,b=5,c=6;  printf(“%dn”,fun(2*a,fun(b,c)))}程序运行后的输出结果是A)3    B)6     C)8      D)12(34)设函数中有整型变量n,为保证其在未赋值的情况下初值为0,应选择的存储类别是A)auto     B) register     C)static     D)auto或register(35)有以下程序#include int b=2;int fun(int *k){ b=*k+b;return (b);}main(){ int a[10]={1,2,3,4,5,6,7,8},I;  for(i=2;i<4;i++) {b=fun(&a)+b;printf(“%d”,b);}  printf(“n”);}程序运行后输出的结果是A)10  12     B)8   10     C)10   28     D)10   16(36)有以下程序#include #define PT 3.5;#define S(x) PT*x*x;mian(){ int a=1, b=2; printf(“%4.1fn”,S(a+b));}程序运行后输出的结果是A)14.0     B)31.5    C)7.5   D)程序有错无输出结果(37)有以下程序#include struct ord{ int x,y;} dt[2]={1,2,3,4};main(){ struct ord *p=dt;  printf (“%d,”,++p->x); printf(“%dn”,++p->y);}程序的运行结果是A)1,2     B)2,3      C)3,4    D)4,1(38)设有宏定义:#include  IsDIV(k,n) ((k%n==1)?1:0且变量m已正确定义并赋值,则宏调用:IsDIV(m,5)&& nIsDIV(m,7)为真时所要表达的是A)判断m是否能被5或者7整除B)判断m是否能被5和7整除C)判断m被5或者7整除是否余1D)判断m被5和7整除是否余1(39)有以下程序#include main(){ int a=5,b=1,t;  t=(a<<2|b); printf(“%dn”,t)  }程序运行后的输出结果是A)21     B)11     C)6       D)1(40)有以下程序#include main(){ EILE *f;  f=fopen(“filea.txt”,”w”);  fprintf(f,”abc”);  fclose(f);}若文本文件filea.txt中原有内容为:hello,则运行以上程序后,文件filea.txt中的内容为A) helloabc        B)abclo       C)abc      D)abchello二、填空题(每空2分,共30分)    请将每一个空的正确答案写在答题卡【1】至【15】序号的横线上,答在试卷上不得分。(1)假设一个长度为50的数组(数组元素的下标从0到49)作为栈的存储空间,栈底指针bottom指向栈底元素,栈顶指针top指向栈顶元素,如果bottom=49,top=30(数组下标),则栈中具有 【1】 个元素。(2)软件测试可分为白盒测试和黑盒测试。基本路径测试属于  【2】 测试。(3)符合结构化原则的三种基本控制结构是:选择结构、循环结构和  【3】 。(4)数据库系统的核心是  【4】(5)在E-R图中,图形包括矩形框、菱形框、椭圆框。其中表示实体联系的是  【5 】框。(6)表达式(int)((double)(5/2)+2.5)的值是【6】(7)若变量x、y已定义为int类型且x的值为99,y的值为9,请将输出语句printf(【7】,x/y);补充完整,使其输出的计算结果形式为:x/y=11(8)有以下程序#include main( ){    char c1,c2;     scanf(“&c”,&c1);     while(c1<65||c1>90)       scanf(“&c”,&c1);     c2=c1+32;     printf(“&c, &cn”,c1,c2);}程序运行输入65回车后,能否输出结果、结束运行(请回答能或不能)【8】 。(9)以下程序运行后的输出结果是【9】#include nmain( ){int k=1,s=0;do{if{((k&2)!=0)continue;s+=k;k++;}while(k)10);printf(“s=&d/n”,s);}(10)下列程序运行时,若输入labced12df<回车> 输出结果为【10】 #include main( ){char  a =0,ch;while((ch=getchar())!=’n’){if(a&2!=0&&(ch>’a’&&ch<=’z’)) ch=ch-‘a’+’A’;a++;putchar(ch);}printf(“n”);}(11)有以下程序,程序执行后,输出结果是【11】#include void fun (int *a){a[0=a[1];]}main(){int a[10]={10,9,8,7,6,5,4,3,2,1},i;for(i=2;i>=0;i--) fun{&a};for(i=0;i<10;i++) printf(“&d”,a);printf(“n”);}(12)请将以下程序中的函数声明语句补充完整#include int【12】 ;main( ){int x,y,(*p)();p=max;printf(“&dn”,&x,&y);}Int max(int a,int b){return (a>b/a:b);}(13)以下程序用来判断指定文件是否能正常打开,请填空#include main( ){FILE *fp;if (((fp=fopen(“test.txt”,”r”n))==【13】))printf(“未能打开文件!n”);elseprintf(“文件打开成功!n”);(14)下列程序的运行结果为【14】#include #include struct A{int a;char b[10];double  c;};void  f (struct  A   *t);main(){struct A a=(1001,”ZhangDa”,1098,0);f(&a);printf(“&d,&s,&6,ifn”,a.a,a.b,a.c);}void f(struct  A  *t){strcpy(t->b,”ChangRong”);   }(15)以下程序把三个NODETYPE型的变量链接成一个简单的链表,并在while循环中输出链表结点数据域中的数据,请填空#include struct node{int data; struct node *next;};typedef struct node NODETYPE;main(){NODETYPE a,b,c,*h,*p;a. data=10;b.data=20;c.data=30;h=&a;b. next=&b;b.next=&c;c.next=’’;p=h;while(p){printf(“&d”,p->data);【15】;}}2009年4月二级C参考答案选择题:1~10: DACDC    ABABC11~20:CBDDA    CDBCB21~30:CDABA    BACBC31~40:ADBCC    nCBDAC填空题:(1)19(2)白盒(3)顺序结构(4)数据库管理系统(DBMS)(5)菱形(6)4(7)"x/y=%d"(8)能(9)s=0(10)1AbCeDf2dF(11)7777654321(12)max(int a,int b)(13)NULL(14)1001,ChangRong,1098.0(15)p=p—>next2009年9月全国计算机等级考试二级笔试试卷 C语言程序设计(考试时间90分钟,满分100分)一、选择题((1)—(10)、(21)—(40)每题2分,(11)—(20)每题1分,共70分)(1)下列数据结构中,属于非线性结构的是A)循环队列B)带链队列C)二叉树D)带链栈(2)下列数据结果中,能够按照“先进后出”原则存取数据的是A)循环队列B)栈C)队列D)二叉树(3)对于循环队列,下列叙述中正确的是nA)队头指针是固定不变的B)队头指针一定大于队尾指针C)队头指针一定小于队尾指针D)队头指针可以大于队尾指针,也可以小于队尾指针(4)算法的空间复杂度是指A)算法在执行过程中所需要的计算机存储空间B)算法所处理的数据量C)算法程序中的语句或指令条数D)算法在执行过程中所需要的临时工作单元数(5)软件设计中划分模块的一个准则是A)低内聚低耦合B)高内聚低耦合C)低内聚高耦合D)高内聚高耦合(6)下列选项中不属于结构化程序设计原则的是A)可封装D)自顶向下C)模块化D)逐步求精(7)软件详细设计产生的图如下:该图是A)N-S图B)PAD图C)程序流程图D)E-R图n(8)数据库管理系统是A)操作系统的一部分B)在操作系统支持下的系统软件C)一种编译系统D)一种操作系统(9)在E-R图中,用来表示实体联系的图形是A)椭圆图B)矩形C)菱形D)三角形(10)有三个关系R,S和T如下:      其中关系T由关系R和S通过某种操作得到,该操作为A)    选择B)     投影C)    交D)    并(11)以下叙述中正确的是A)程序设计的任务就是编写程序代码并上机调试B)程序设计的任务就是确定所用数据结构C)程序设计的任务就是确定所用算法D)以上三种说法都不完整(12)以下选项中,能用作用户标识符的是A)voidB)8_8C)_0_D)unsigned(13)阅读以下程序n#includemain(){intcase;floatprintF;printf(“请输入2个数:”);scanf(“%d%f”,&case,&pjrintF);printf(“%d%fn”,case,printF);}该程序编译时产生错误,其出错原因是A)定义语句出错,case是关键字,不能用作用户自定义标识符B)定义语句出错,printF不能用作用户自定义标识符C)定义语句无错,scanf不能作为输入函数使用D)定义语句无错,printf不能输出case的值(14)表达式:(int)((double)9/2)-(9)%2的值是A)0B)3C)4D)5(15)若有定义语句:intx=10;,则表达式x-=x+x的值为A)-20B)-10C)0D)10(16)有以下程序#includemain(){inta=1,b=0;printf(“%d,”,b=a+b);printf(“%dn”,a=2*b);}程序运行后的输出结果是A)0,0B)1,0C)3,2D)1,2n17)设有定义:inta=1,b=2,c=3;,以下语句中执行效果与其它三个不同的是A)if(a>b)c=a,a=b,b=c;B)if(a>b){c=a,a=b,b=c;}C)if(a>b)c=a;a=b;b=c;D)if(a>b){c=a;a=b;b=c;}(18)有以下程序#includemain(){intc=0,k;for(k=1;k<3;k++)switch(k){default:c+=kcase2:c++;break;case4:c+=2;break;}printf(“%dn”,c);}程序运行后的输出结果是A)3B)5C)7D)9(19)以下程序段中,与语句:k=a>b?(b>c?1:0):0;功能相同的是A)if((a>b)&&(b>c))k=1;elsek=0;B)if((a>b)||(b>c)k=1;elsek=0;C)if(a<=b)k=0;elseif(b<=c)k=1;D)if(a>b)k=1;elseif(b>c)k=1;elsek=0;20)有以下程序#includemain()n{chars[]={“012xy”};inti,n=0;for(i=0;s[i]!=0;i++)if(s[i]>=’a’&&s[i]<=’z’)n++;printf(“%dn”,n);}程序运行后的输出结果是A)0B)2C)3D)5(21)有以下程序#includemain(){intn=2,k=0;while(k++&&n++>2);printf(“%d%dn”,k,n);}程序运行后的输出结果是A)02B)13C)57D)12(22)有以下定义语句,编译时会出现编译错误的是A)chara=’a’;B)chara=’n’;C)chara=’aa’;D)chara=’x2d’;(23)有以下程序#includemain(){charc1,c2;c1=’A’+’8’-‘4’;c2=’A’+’8’-‘5’;printf(“%c,%dn”,c1,c2);}n已知字母A的ASCII码为65,程序运行后的输出结果是A)E,68B)D,69C)E,DD)输出无定值(24)有以下程序#includevoidfun(intp){intd=2;p=d++;printf(“%d”,p);}main(){inta=1;fun(a);printf(“%dn”,a);}程序运行后的输出结果是A)32B)12C)21D)22(25)以下函数findmax拟实现在数组中查找最大值并作为函数值返回,但程序中有错导致不能实现预定功能#defineMIN-2147483647intfindmax(intx[],intn){inti,max;for(i=0;inmain(){intm=1,n=2,*p=&m,*q=&n,*r;r=p;p=q;q=r;printf(“%d,%d,%d,%dn”,m,n,*p,*q);}程序运行后的输出结果是A)1,2,1,2B)1,2,2,1C)2,1,2,1D)2,1,1,2(27)若有定义语句:inta[4][10],*p,*q[4];且0≤i<4,则错误的赋值是A)p=aB)q[i]=a[i]C)p=a[i]D)p=&a[2][1](28)有以下程序#include#includemain(){charstr[][20]={“One*World”,“One*Dream!”},*p=str[1];printf(“%d,”,strlen(p));printf(“%sn”,p);}程序运行后的输出结果是A)9,One*WorldB)9,One*DreamC)10,One*DreamD)10,One*World(29)有以下程序#includemain(){inta[]={2,3,5,4},i;for(i=0;i<4;i++)switch(i%2){case0:switch(a[i]%2)n{case0:a[i]++;break;case1:a[i]--;}break;case1:a[i[=0;}for(i=0;i<4;i++)printf(“%d”,a[i]);printf(“n”);}A)3344B)2050C)3040D)0304(30)有以下程序#include#includemain(){chara[10]=”abcd”;printf(“%d,%dn”,strlen(a),sizeof(a));}程序运行后的输出结果是A)7,4B)4,10C)8,8D)10,10(31)下面是有关C语言字符数组的描述,其中错误的是A)不可以用赋值语句给字符数组名赋字符串B)可以用输入语句把字符串整体输入给字符数组C)字符数组中的内容不一定是字符串D)字符数组只能存放字符串(32)下列函数的功能是fun(char*a,char*b){while((*b=*a)!=’’){a++,b++;}}A)将a所指字符串赋给b所指空间B)使指针b指向a所指字符串C)将a所指字符串和b所指字符串进行比较D)检查a和b所指字符串中是否有’’n (33)设有以下函数voidfun(intn,char*s){……}则下面对函数指针的定义和赋值均是正确的是A)void(*pf)();pf=fun;B)viod*pf();pf=fun;C)void*pf();*pf=fun;D)void(*pf)(int,char);pf=&fun;(34)有以下程序#includeintf(intn);main(){inta=3,s;s=f(a);s=s+f(a);printf(“%dn”,s);}intf(intn){staticinta=1;n+=a++;returnn;}程序运行以后的输出结果是A)7B)8C)9D)10(35)有以下程序#include#definef(x)x*x*xmain(){inta=3,s,t;s=f(a+1);t=f((a+1));printf(“%d,%dn’,s,t);}程序运行后的输出结果是A)10,64B)10,10nC)64,10D)64,64(36)下面结构体的定义语句中,错误的是A)structord{intx;inty;intz;};structorda;B)structord{intx;inty;intz;}structorda;C)structord{intx;inty;intz;}a;D)struct{intx;inty;intz;}a;(37)设有定义:char*c;,以下选项中能够使字符型指针c正确指向一个字符串的是A)charstr[]=”string”;c=str;B)scanf(“%s”,c);C)c=getchar();D)*c=”string”;   (38)有以下程序#include   #includestructA{inta;charb[10];doublec;};structAf(structAt);main(){structAa={1001,”ZhangDa”,1098.0};a=f(a);jprintf(“%d,%s,%6.1fn”,a.a,a.b,a.c);}structAf(structAt)(t.a=1002;strcpy(t.b,”ChangRong”);t.c=1202.0;returnt;)程序运行后的输出结果是A)1001,ZhangDa,1098.0B)1001,ZhangDa,1202.0C)1001,ChangRong,1098.0D)1001,ChangRong,1202.0   (39)若有以下程序段intr=8;printf(“%dn”,r>>1);输出结果是nA)16B)8C)4D)2   (40)下列关于C语言文件的叙述中正确的是A)文件由一系列数据依次排列组成,只能构成二进制文件B)文件由结构序列组成,可以构成二进制文件或文本文件C)文件由数据序列组成,可以构成二进制文件或文本文件D)文件由字符序列组成,其类型只能是文本文件二、填空题(每空2分,共30分)(1)某二叉树有5个度为2的结点以及3个度为1的结点,则该二叉树中共有【1】个结点。(2)程序流程图中的菱形框表示的是【2】。(3)软件开发过程主要分为需求分析、设计、编码与测试四个阶段,其中【3】阶段产生“软件需求规格说明书。(4)在数据库技术中,实体集之间的联系可以是一对一或一对多或多对多的,那么“学生”和“可选课程”的联系为【4】。(5)人员基本信息一般包括:身份证号,姓名,性别,年龄等。其中可以作为主关键字的是【5】。(6)若有定义语句:inta=5;,则表达式:a++的值是【6】。(7)若有语句doublex=17;inty;,当执行y=(int)(x/5)%2;之后y的值为【7】。(8)以下程序运行后的输出结果是【8】。#includemain(){intx=20;printf(“%d”,0main(){inta=1,b=7;do{b=b/2;a+=b;}while(b>1);printf(“%dn”,a);}(10)有以下程序#includemain(){intf,f1,f2,i;f1=0;f2=1;printf(“%d%d”,f1,f2);for(i=3;i<=5;i++){f=f1+f2;printf(“%d”,f);f1=f2;f2=f;}printf(“n”);}程序运行后的输出结果是【10】。(11)有以下程序#includeinta=5;voidfun(intb){inta=10;a+=b;printf(“%d”,a);}main(){intc=20;fun(c);a+=c;printf(“%dn”,a);}程序运行后的输出结果是【11】。(12)设有定义:nstructperson{intID;charname[12];}p;请将scanf(“%d”,【12】);语句补充完整,使其能够为结构体变量p的成员ID正确读入数据。(13)有以下程序#includemain(){chara[20]=”Howareyou?”,b[20];scanf(“%s”,b);printf(“%s%sn”,a,b);}程序运行时从键盘输入:Howareyou?<回车>则输出结果为【13】。(14)有以下程序#includetypedefstruct{intnum;doubles}REC;voidfun1(RECx){x.num=23;x.s=88.5;}main(){RECa={16,90.0};fun1(a);printf(“%dn”,a.num);}程序运行后的输出结果是【14】。(15)有以下程序#includefun(intx){if(x/2>0)run(x/2);printf(“%d”,x);}main(){fun(6);printf(“n”);}程序运行后的输出结果是【15】n2009年9月全国计算机等级考试二级C语言笔试参考答案一、选择题(1)C(2)B(3)D(4)A(5)B(6)A(7)C(8)B(9)C(10)D11)D(12)C(13)A(14)B(15)B(16)D(17)C(18)A(19)A(20)B(21)D(22)C(23)A(24)C(25)D(26)B(27)A(28)C(29)C(30)B(31)D(32)A(33)A(34)C(35)A(36)B(37)A(38)D(39)C(40)C二、填空题(1)14(2)逻辑条件(3)需求分析(4)多对多(5)身份证号(6)5(7)1(8)10(9)5n(10)01123*答案仅供参考
查看更多

相关文章

您可能关注的文档