[计算机类试卷]2010年上半年软件水平考试(初级)程序员下午(应用技术)试题真题试卷及答案与解析.doc
《[计算机类试卷]2010年上半年软件水平考试(初级)程序员下午(应用技术)试题真题试卷及答案与解析.doc》由会员分享,可在线阅读,更多相关《[计算机类试卷]2010年上半年软件水平考试(初级)程序员下午(应用技术)试题真题试卷及答案与解析.doc(16页珍藏版)》请在麦多课文档分享上搜索。
1、2010年上半年软件水平考试(初级)程序员下午(应用技术)试题真题试卷及答案与解析 1 阅读以下说明和流程图,填补流程图中的空缺 (1) (5),将解答填入对应栏内。说明 下面的流程图旨在统计指定关键词在某一篇文章中出现的次数。 设这篇文章由字符 A(0), , A(n-1)依次组成,指定关键词由字符 B(0), , B(m-1)依次组成,其中, n m1。注意,关键词的各次出现不允许有交叉重叠。例如,在 “aaaa”中只出现两次 “aa”。 该流程图采用的算法是:在字符串 A中,从左到右寻找与字符串 B相匹配的并且没 有交叉重叠的所有子串。流程图中, i为字符串 A中当前正在进行比较的动态予
2、串首字符的下标, j为字符串 B的下标, k为指定关键词出现的次数。 流程图 2 函数 inputArr(int a, int n)的功能是输入一组整数 (输入 0或输入的整数个数达到n时结束 )存入数组 a,并返回实际输入的整数个数。函数 inputArr可以成功编译。但测试函数调用 inputArr后,发现运行结果不正确。 请指出错误所在的代码行号,并在不增加和删除代码行的情况下进行修改,写出修改正确后的完整代码行,使之符合上述设计意图。 C函数 3 分析下面的 C程序,指出错误代码 (或运行异常代码 )所在的行号。 C程序 4 阅读以下说明和 C函数,将应填入 (n)处对应栏内。 说明
3、基于管理的需要,每本正式出版的图书都有一个 ISBN号。例如,某图书的 ISBN号为 “978-7-5606-2348-1”。 ISBN号由 13位数字组成:前三位数字代表该出版物是图书 (前缀号 ),中间的 9个数字分为三组,分别表示组号、出版者号和书名号,最后一个数字是校验码。其中,前缀号由国际 EAN提供,已经采用的前缀号为 978和 979;组号用以区别出版 者国家、地区或者语言区,其长度可为 1 5位;出版者号为各出版者的代码,其长度与出版者的计划出书量直接相关;书名号代表该出版者该出版物的特定版次;校验码采用模 10加权的算法计算得出。 校验码的计算方法如下: 第一步:前 12位数
4、字中的奇数位数字用 l相乘,偶数位数字用 3相乘 (位编号从左到右依次为 13到 2)。 第二步:将各乘积相加,求出总和 S。 第三步:将总和 S除以10,得出余数 R。 第四步:将 10减去余数 R后即为校验码 V。若相减后的数值为10,则校验码为 0。 例如,对于 ISBN号 “978-7-5606-2348-1”,其校验码为 1,计算过程为: S=91+73+81+73+51+63+01+63+21+33+41+83=139 R=139mod 10=9 V=10-9=1 函数 check(char code)用来检查保存在 code中的一个ISBN号的校验码是否正确, 若正确则返回 tr
5、ue,否则返回 false。例如, ISBN号“978-7-5606-2348-1”在 code中的 存储布局如表 3-1所示 (书号的各组成部分之间用“-”分隔 ):表 3-1 数组 code的内容示例在函数 check(char code)中,先将 13位 ISBN号放在整型数组元素 tarr0 tarr12中(如表 3-2所示,对应 ISBN号的位 13位 1),由 tarr0 tarr11计算出校验码放入变量 V,再进行判断。 表 3-2 数组 tarr的内容示例 C函数 boo1 cheCk(char code) int i, k=0; intS=0, temp=0; int V;
6、int tarr13=0; if (Strlen(code) 17 return falSe; for(i=0; i 17; i+) /*将 13位 ISBN号存入 tarr*/ if(codei!=-) tarr (1)_ =codei-0; for(i=0; (2)_ ; i+ ); if (i%2) S+= (3)_ ; else S+= (4)_ ; v=( (5)_ =C)?0:10-s%10; if(tart12=v) return true ; return false; 5 阅读以下说明和 C程序,将填入 (n) 处的字句在对 应栏内。 说明 某旅游服务应用程序运行时,根据输入
7、的两个城市名查找其问的距离。各城市问的距离如表 4-1所示。表格中的第一行和第一列表示城市名,表中的每个元素是一个整数,代表该元素所在行和列对应的城市之间的距离 (单位: km)。表 4-1 在程序中,城市名用一维全局数组 cityTable存储,城市之间的距离矩阵用二维全局数组 kmTable表示,并用相应的值对这两个数组进行初始化。 #define NCities 8 /*城市个数 */ #define TRUE 1 static char * cityTableNCities= /*城市名按字典序升序排列 */ “Beijing“, /* 其他城市名略去 */ “Sanya“, ; St
8、atiC int kmTableNCitiesNCities= 0, 1697, 2695, 937, 1784, 1356, 926, 2543, 1697, 0, 313, 1840, 533, 940, 1409,1505, /* 剩余元素的初始值略去 */ ; 程序执行时,首先按提示输入两个城市名,然后在 cityTable中查找与城市名对应的 下标,最后用该下标在 kmTable中找到这两个城市之间的距离。 程序中定义的函数FindCitylnSortedArray和 GetCity说明如下: (1)函数 FindCitylnSortedArray的功能是用二分查找法在全局数组 ci
9、tyTable中查找城市名所对应的下标值。 (2)函数GetCity的功能是读入城市名,调用函数 FindCityInSortedArray来获取城市所对应的下标值。如果该城市名不存在,则提示用户重新输入。 C程序 int main() int city1, city2; city1=GetCity(“输入第 1个城市名: “); city2=GetCity(“输入第 2个城市名: “); printf(“%S和 %s之间的距离为: %d km.n”, cityTablecity1, cityTablecity2, kmTablecitylcity2); return 0; StatiC in
10、t GetCity(char * prompt) char * CityName; int index; cityName=(char *)malloc(20*sizeof(char); while(TRUE) printf(“%S“,prompt); gets(cityName); /*获取输入字符串 */ index=FindCityInSortedArray(cityName); if( (1) _ )break; printf(“城市名不存在,请重新输入。 n“); free(cityName); return (2)_; Static int FindCityInSortedArra
11、y(char * key) int lh, rh, mid, cmp; lh=0; rh=NCities-1; while( (3)_) mid=(1h+rh)/2; cmp=strcmp( (4)_ ); /*比较两个城市名是否相同 */ if(cmp=0)return (5)_; /*两个城市名相同 */ if(cmp 0)rh=mid-1;) else lh=mid+1;) return (-1); /*城市名不存在时返回 -1 */ 6 阅读以下说明和 C+代码,将填入 (n) 处 的字句在应栏内。 说明 现需要统计某企业员工的月平均: 资,即该企业本月发给员工的工资总和除以员工数。假
12、设企业本月发给员工的工资总和为 sumSalary,该企业的员工总数为employeeNumber,下面的程序代码计算该企业员工本月的平均工资,其中需要处理 employNumber为 0的情况。 C+代码 #include using namespace std; class Department protected: float average(float x, int y) if(Y=O) throw (1)_ ; return x/y; public: void caculate(void) float sumSalary; int employeeNumber; try cout “
13、请输入当月工资总和与员工数: “ endl; cin sumSalary employeeNumber: float k=average(sumSalary, employeeNumber); cout “平均工资: “ k endl; (2)_ (int e) if(e=0) cout “请重新输入当月工资总和与员工数: “ endl; cin sumSalary employeeNumber; float k=average(sumSalary, employeeNumber); cout “平均工资: “ k endl; ; VOid msin() try (3)_ ; d.cacula
14、te(); (4)_ (int e) if(e=0) cout “程序未正确计算平均工资 !“ endl; 问题 1 程序运行时,若输入的员工工资总和为 6000,员工数为 5,则屏幕输出为: 请输入当月工资总和与员工数: 6000 5 (5)_ 问题 2 若程序运行时,第一次输入的员工工资总和为 6000,员工数为 0,第二次输入的员工工资总和为 0,员工数为 0,则屏幕输出为: 请输入当月工资总和与员工数: 6000 0 (6)_ 0 0 (7)_ 7 阅读以下说明和 Java代码,将填入 (n) 处的字句在对应栏内。 说明 现需要统计某企业员工的月平均工资,即该企业本月发给员工的工资总和
15、除以员工 人数。假设企业本月发给员工的工资总和为 sumSalary,该企业的员工总数为employeeNumber,下面的程序代码计算该企业员工本月的平均工资,其中需要处理 employNumber为 0的情况。 Java代码 import Java.util.Scanner; public class JavaMain static float average(float X, int Y)throws Exception if(Y=0)throw new Exception( (1)_ ); return X/Y; Static Void caculate()throws Excepti
16、on float sumSalary; int employeeNumber; Scanner SC=new Scanner( (2)_); try System.out.println(“请输入当月工资总和与员工数: “); sumSalary=sc.nextFloat(); /从标准输入获得工资总和 employeeNumber=SC nextInt(); /从标准输入获得员工数 float k=average(sumSalary, employeeNumber); System.out.println(“平均工资: “+k); (3)_ (Exception e) if(e.getMeS
17、Sage().equalSIgnoreCase(“zero“) System.out.println(“请重新 输入当月工资总和与员工数: “); sumSalary=sc.nextFloat(); employeeNumber=sc.nextInt(); float k=average(sumSalary, employeeNumber); System.out.println(“平均工资: “+k); public Static void msin(String argS) try caculate(); (4)_ (Exception e) if ( e.getMessage() equ
18、alsIgnoreCase(“zero“) system.out.println(“程序未正确计算平均工资 !“); 问题 1 程序运行时,若输入的员工工资总和为 6000,员工数为 5,则屏幕输出为: 请输入当月工资总和与员工数: 6000 5 (5)_ 问题 2 若程序运行时,第一次输入的员工工资总和为 6000,员工数为 0,第二次输入的员工工资总和为 0,员工数为 0,则屏幕输出为: 请输入当月工资总和与员工数: 6000 0 (6)_ 0 0 (7)_ 2010年上半年软件水平考试(初级)程序员下午(应用技术)试题真题试卷答案与解析 1 【正确答案】 0-k i+j i+m i+1
- 1.请仔细阅读文档,确保文档完整性,对于不预览、不比对内容而直接下载带来的问题本站不予受理。
- 2.下载的文档,不会出现我们的网址水印。
- 3、该文档所得收入(下载+内容+预览)归上传者、原创作者;如果您是本文档原作者,请点此认领!既往收益都归您。
下载文档到电脑,查找使用更方便
2000 积分 0人已下载
下载 | 加入VIP,交流精品资源 |
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机 试卷 2010 上半年 软件 水平 考试 初级 程序员 下午 应用技术 试题 答案 解析 DOC

链接地址:http://www.mydoc123.com/p-492892.html