ImageVerifierCode 换一换
格式:DOC , 页数:181 ,大小:4.83MB ,
资源ID:982852      下载积分:20 积分
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 微信支付   
验证码:   换一换

加入VIP,免费下载资源
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【http://www.wodocx.com/d-982852.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(全国计算机三级网络技术上机习题100套.doc)为本站会员(风****)主动上传,沃文网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知沃文网(发送邮件至2622162128@qq.com或直接QQ联系客服),我们立即给予删除!

全国计算机三级网络技术上机习题100套.doc

1、第1套上机考试试题调用函数rwdata(),从IN.dat文件中读取10组数据(m和k值),并嵌套调用primenum函数分别得出array数组。请编写函数primenum(int m,int k,int array),该函数的功能是:将紧靠m的k个素数存入数组array并在屏幕上显示。最后把结果输出到文件OUT.dat中。例如,若输入3 9,则应输出5 7 11 13 17 19 23 29 31。注意:部分程序已经给出。请勿改动丰函数main()和输出数据函数rwdata()的内容。第1套试题答案及详解【知识点播】素数的定义:如果一个数的正因子只有1和这个数本身,那么这个数就是素数。【审题

2、分析】分析题目可知,题中需要解决的问题就是Primenum函数的功能问题(rwdata函数功能题中已经给出),而Primenum函数的功能是求在指定数m之后的k个素数,因此本题的关键在于如何判断一个数是素数,之后就可以通过一个for循环来求得在m之后的k个素数了。【解题思路】根据素数的定义,本题采用的算法是:首先定义一个变量Value,并把m之后的数逐个赋值给该变量:然后用2value2数除value,如果value能被2value2之中的任何一个整数整除,则value不是素数,结束循环;如果value小能被2value2之间的任一整数整除,则退出循环,然后判断循环变量i是否大于value2,

3、如果大于,则value是素数,并将value值赋给arrayn,然后n+;再判断n是否大于等于k,如果大于等于k,就完成了程序要求的功能,退出循环,否则value加1,根据以上算法继续进行。【参考答案】【易错分析】判断一个数m(大于1)是否素数的简单的算法:枚举2到m2之间的整数,看能否被m整除,如果能整除,就不是素数,否则是素数。【考点链接】c语言中循环语句、if语句的应用和素数的算法。第2套上机考试试题在文件IN.dat中有200个正整数,且每个数均在1000-9999之间。函数RData()读取这200个数存放到数组0riginal中。请编写函数numAscend(),其功能是:要求按每

4、个数的后3位的大小进行升序排列,然后取出满足此条件的前10个数依次存入数组result中,如果后3位的数值相等,则按原先的数值进行降序排列。最后调用函数WData(),把结果result输出到文件OUT.dat中。例如,处理前:6012 5099 9012 7025 8088处理后:9012 6012 7025 8088 5099注意:部分程序已给出。请勿改动主函数main()、读数据函数RData()和输出数据函数WData()盼内容。第2套试题答案及详解【审题分析】首先我们来看看题中要求我们解决的问题有哪些。按original数组中各元素数字的后3位数的大小进行升序排列,如果数值相等,则按

5、原先的数值进行降序排列;取出排序后的original数组中的前10个数依次存入result数组中。【解题思路】根据上面的分析,编写程序有以下几个步骤:第1步:首先分解出数组中两个元素的后三位,这里采用在两次循环中求出正整数originali矛n originalj对1000的余数的方法;第2步:然后比较两个数余数的大小,如果正整数0riginali和originalj对1000的余数不相同,则按照升序进行排序,如果相同,则比较originali和originalj的大小,按照降序进行排序;第3步:利用一个for循环语句把original数组中的前10个数输出给result数组。【参考答案】【易

6、错分析】数组originali中两个数的位置交换要借助中间变量data。【考点链接】for循环语句、正整数的求余运算。第3套上机考试试题已知文件lN.dat中存有100个产品销售记录,每个产品销售记录由产品代码code(字符型4位)、产品名称name(字符型10位)、单价uprice(整型)、数量amount(整型)、金额sum(长整型)5部分组成。其中:金额=单价数量。函数RData0读取这100个销售记录并存入结构数组sell中。请编写函数DescSort0,其功能要求:按产品代码从大Nd,进行排列,若产品代码相同,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函

7、数WData0,把结果输出到文件OUT.dat中。注意:部分程序已给出。请勿改动主函数main()、读数据函数RData()和输出数据函数WData()的内容。第3套试题答案及详解【审题分析】首先我们来看看题中要求我们解决的问题有哪些。按产品代码从大到小进行排列,若产品代码相同,则按金额从大到小进行排列;将排列结果存入结构数组sell巾。分析题目可知,本题中使用结构数组sell来保存销售记录。产品代码存储在sell结构数组中的code成员中,金额存储存sum成员中。【解题思路】我们可以利用两个for循环结构对产品销售记录(strcmp(selli.code.sellj.code)两两进 行循环

8、比较,如果这个表达式返回结果值小于0,则进行两个数据的交换,实现产品代码从大到小进行排序。如果上面的表达式的返回值等于0,说明这两个产品的代码相司,则比较seHi.sum与sellj.sum的值。如果sellisumj.sum,则进行两个数据的交换,实现金额从大到小进行排序。【参考答案】【易错分析】数组selli中两个数的位置交换要借助中间变量temp。【考点链接】数组中两个数的交换、字符串比较函数strcmp。第4套上机考试试题函数RData()实现从文件IN.dat中读取一篇英文文章,存入到字符串数组str中;请编写encryptChar()函数,其功能是:按给定的替代关系对数组str中的

9、所有字符进行替代,仍存入数组sir对应的位置上,最后调用函数WData(),把缔果str输出到文件OUT.dat中。替代关系:f(p)=p*11 mod 256(p是数组中某一个字符的ASCII值,f(p)足计算后新字符的ASCII值),如果计算后f(p)值小于等于32或大于130,则该字符不变,否则将f(p)所对应的字符进行替代。始数据文件存放的格式是:每行的宽度均小于80个字符。注意:部分程序已给出。请勿改动主函数main()、读数据函数RData()和输出数据函数WData()的内容。第4套试题答案及详解【审题分析】分析题目可知,题中需要解决的问题就是实现encryptChar函数的功能

10、问题,而encryptChar函数的功能是:实现“按照指定的替代关系将数组str中的所有字符进行替代,替代后仍存入数组str的对应位置上”。因此本题的关键在于用什么样的C程序语言实现指定的替代关系,之后就可以通过一个双重循环来将这篇文章中的所有字符逐个替换。【解题思路】首先通过for循环对数组siri巾的每一个英文字符按照题目给定的替代算法*pf*11256计算出其对应的字符的ASCII值,然后把这个ASCII值与130和32进行比较,如果这个值小于等于130且人于32,则用这个ASCII值代替代原值。【参考答案】【易错分析】题目中的条件是:如果计算后f(p)值小于等于32或大于130,则该字

11、符不变。在程序中这个条件写成:*pf*1125632。【考点链接】按照规定的算法f(p)p*11 mod 1256进行字符的相互替换。第5套上机考试试题函数RData0实现从文件INdat中读取一篇英文文章存入到宁符串数组str中,请编写函数DescSort(),其功能是:以行为单位对字符按从大到小的顺序进行排序,排序后的结果仍按行重新存入字符串数组str中,最后调用函数WData(),把结果str输出到文件OUT.dat中。原始数据文件存放的格式是:每行的宽度均小于80个宁符(含标点符号和空格)。例如,原文:dAeBfCCcbbAA结果:fedCBAcbbCAA注意:部分程序已给出。请勿改动

12、主函数main()、读数据函数RData()和输出数据函数WData()的内容。 来源:考试大-计算机等级考试第5套试题答案及详解【审题分析】分析题目可知,题中需要解决的问题就是实现DescSort函数的功能问题,而DescSort函数的功能是:实现“以行为单位对字符按从大到小的顺序进行排序,排序后韵结果仍按行重新存入字符串数组str中”。因此本题的关键在于如何判断将字符串拆分成单独的字母,之后就可以通过一个三重循环来将所有字符逐个比较字母的大小,并存入数组str中。【解题思路】首先利用三重循环中的第一层循环将字符读入数组str1中,然后利用内层的二重循环对文章中每一行的字符进行两两比较,较小

13、的字符往行后放,较大的字符往行前放,这样就实现了以行为单位对字符从大到小的排序。在程序中的语句是if(strij)束实现,左移运算符为(4;再和originalij的值相加;最后将得到的ASCII码值转换成字符并存入数组original中。【参考答案】【易错分析】字符的ASCII码值右移4位,再和原值相加,用语句originalij+originalij4实现。【考点链接】每个字符的ASCII码值存移4位,即originalij4第7套上机考试试题编写函数findStr(),其功能足:统计一个长度为2的子字符串在另一个字符串中出现的次数。例如,似定输入的宁符串为“asd asasdfg asd

14、 as zx67 asd mkl0”,子字符串为”as”,函数返回值是6。函数ReadWrite()实现从文件IN.dat中读取两个字符串,并调用函数findStr(),最后,把结果输出到文件OUT._dat中。注意:部分程序已经给出。请勿改动主函数main()和其他函数中的任何内容,仅住函数findStr()的花括号中填入编写的若干语句。来源:考试大-计算机等级考试第7套试题答案及详解【审题分析】分析题目可知,题中需要解决的问题就是实现findStr函数的功能问题,而findStr函数的功能是:统计满足“一个长度为2的子字符串在另一一个字符串”条件的字符串出现的次数。因此本题的关键在于如何判

15、断一个字符串在另外一个字符串中。【解题思路】这里用字符指针P和r分别指向字符串和予字符串,在while循环中比较*r和+p的值,如果两者的值相等,则r和P分别加l:如果两者不相等,则对*r的值进行判断。如果*r的值等于0,则说明在字符串*str中找到了一个与*substr相匹配的字符串,所以n加1。然后str加1,进入下一个寻找与子字符相匹配循环,直到退出while(*str)循环,返回的整数n值就是与子字符串相匹配字符串的个数。【参考答案】1 int findStr(char*Str,char*subStr)【易错分析】字符串的最后一个字符是null,所以当字符串指针str和r达到字符串的结

16、尾时,就自动退出while循环。【考点链接】在字符串中寻找与子字符串相匹配的字符串个数。第8套上机考试试题请编写函数CountValue(),它的功能是:求n以内(不包括n),同时能被3与7整除的所有自然数之和的平方根S,并作为函数值返回。主函数最后调用函数progReadWrite0从IN.dat文件中读取10组数据,分别得出结果,且把结果输出到文件0UT.dat中。例如,若n为1000时,函数值应为:s=153.909064。注意:部分程序已经给出。请勿改动主函数main()和输入输出数据函数progReadWrite()的内容。来第8套试题答案及详解【审题分析】分析题目可知,CountV

17、alue()函数要实现3个功能:求出n以内所有能被3和7整除的整数;将这些整数相加求它们的和;对这个和求平方根。【解题思路】这里我们先通过for循环语句来求出12以内所有能被3和7整除的整数同时对这些数求和;然后把和转化为双精度型数据,利用开平方函数sqrt()求出这个和数的平方根。【参考答案】【易错分析】能被3和7整除的整数的条件为:i3O&i70;在求和的平方根之前,首先要把和数的类型转化为双精度型。【考点链接】求余运算、C语言中数据类型的相互转换。第9套上机考试试题已知在文件IN.dat中存有N个(N200)实数,函数RData0读取这N个实数并存入数组original中。请编写函数Ca

18、lValue0,要求实现的功能有:求出这N个实数的平均值(aver);分别求出这N个实数的整数部分之和(sumint)以及小数部分之和(sumdec),最后调用函数wData()把所求的结果输出到文件OUT.dat中。注意:部分源程序已给出。请勿改动主函数main()、读数据函数RData()和输出数据函数wData()的内容。第9套试题答案及详解【审题分析】分析题目可知,函数CalValue()函数要实现2个功能:求出这N个实数的平均值(aver);分别求出这N个实数的整数部分之和(sumint)以及小数部分之和(sumdec)。【解题思路】这里我们可以利用for循环语句对数组origina

19、l中的每一个实数逐个进行处理。对于每一个实数originali,在其数据前面加上(int)就得到这个实数的整数部分;用originali减去(int)originali就得到这个实数的小数部分。然后分别求出MAXNUM个实数的和(sum)、整数部分的和(sumint)、小数部分的和(sumdec)。最后用sum除以MAXNUM就得到平均值(aver)。【参考答案】【易错分析】实数分成整数部分和小数部分,在实数前面加上(int)就得到这个实数的整数部分,实数减去整数部分就得到小数部分。【考点链接】数据类型的转换第10套上机考试试题已知数据文件IN.dat中存有300个网位数,并已调用读函数Rda

20、ta()把这些数存入数组a中,请编写函数primeNum(),其功能是:求出所有这些四位数中素数的个数count,再把所有满足此条件的四位数依次存入数组b中,然后对数组b的四位数按从小到大的顺序进行排序。最后调用写函数Wdata(),把结果输出到OUT.dat文件中。例如,5591是素数,则该数满足条件存入数组b中,且个数count=count+1。9812足非素数,则该数不满足条件,不存入数组b中,count值也不加1。注意:部分源程序已经给出。程序中已定义数组a300、b300,已定义变量count。请勿改动主函数main()、读函数Rdata()和写函数Wdata()的内容。第10套试题

21、答案及详解【审题分析】分析题目可知,本题只要实现primeNum()函数的功能即可。primeNum()要实现的功能是:求出所有这些四位数是素数的个数count,再把所有满足此条件的四位数依次存入数组b中,然后对数组b的网位数按从小到大的顺序进行排序。因此解答本题的关键在于如何判断一个四位数为素数。【解题思路】用for循环对300个整数调用子函数isP(ai)进行判断其是否是素数,如果是素数,则把ai赋给数组b,同时计数变量count加1。最后利用双重循环对数组b中的元素进行从小到大的排序。【参考答案】【易错分析】在两层for循环中,内层循环是从i+1开始直到count。【考点链接】子函数的调

22、用、数组元素的从小到大排序算法第11套上机考试试题下列程序的功能是:把s字符串中的所有字符左移一个位置,字符串中的第一个字符移到最后。请编写函数change(char*s)实现程序要求,最后调用函数readwriteDAT()从IN.dat文件中读取50组数据,分别得出结果,且把结粜输出到OUT.dat文件中。例如,S字符串中原有内容为:Mn.123xyZ,调用该函数后结果为:n.123xyZM。注意:部分源程序已经给出。清勿改动主函数main()和输出数据函数readwriteDAT()中的内容。来第11套试题答案及详解【审题分析】分析题目可知,本题只要实现change(char*s)函数的

23、功能即可。change(char*s)要实现的功能足:把S字符串中的所有字符左移一个位置,串中的第一个字符移到最后。因此解答本题的关键在于如何将字符串拆分成单个字符并赋值给数组,并通过数组的下标将字符逐个左移一位。【解题思路】首先用字符串函数strlen求出字符串S的长度,赋给变量str1再把字符串的首字符赋给字符变最ch:然后在for循环语句中,变量i从0递增到str1-1,字符串s中的所有字符左移一个位置:最后把字符变最ch的值赋给*(s+str1-1),即完成了题目要求的功能。【参考答案】【易错分析】存字符串左移时要首先把首字符存入一个字符变量中。【考点链接】字符串中字符的移动第12套上

24、机考试试题下列程序的功能是:找出所有100以内(含100)满足i、i+4、i+10都是素数的整数i(i+10也在100以内)的个数count以及这些i之和sum。请编写函数primeNum()实现程序要求的功能,最后调用函数writeDat(),把结果count和sum输出剑文件OUT.dat中。注意:部分源程序已经给出。请勿改动主函数main()和输出数据函数writeDat()的内容。来第12套试题答案及详解【审题分析】分析题目可知,本题只要实现primeNum()数的功能即可。primeNum()要实现的功能是:找出所有100以内(含100)满足i、i+4、i+10郝是素数的螺数i(i+

25、10也在100以内)的个数count以及这些i之和sum。因此解答奉题的关键在于如何将“i、i+4、i+10都是素数”条件转换成C语言表达式。【解题思路】在for循环浯句中自变量i从2递增到90,调用子雨数isPrime(),用来判断i、i+4、i+1O这3个数同时为素数是否成立,如果成立,则计数变量count加1,同时把i加到变量sum 上,求得这些i的和。【参考答案】【易错分析】因为i+10要在100以内,所以自变量i的变化范围应该是2到90。【考点链接】子函数的调用第13套上机考试试题函数Rdata()实现从文件IN.dat中读取一篇英文文章存入到字符串数组string中,请编写Conv

26、ertCharD()函数,其功能是:以行为单位把字符串中的所有小写字母改写成该字母的上一个字母,如果是字母a,则改写成字母2。大写字母仍为大写字母,小写字母仍为小写字母,其他字符不变,最后把已处理的字符串仍按行重新存入字符串数组string中。最后调用函数Wdata(),把结果string输出到文件OUT.dat中。例如,原文:AdbBcdzaabck.LLhj结果:Aca.Bbcyzzabj.LLgi原始数据文件存放的格式是:每行的宽度均小于80个字符。注意:部分源程序已经给出。请勿改动主函数main()、读数据函数Rdata()和输出数据函数wdata()的内容。1 #include2 #

27、include第13套试题答案及详解【审题分析】分析题目可知,本题只要实现ConvertCharD()函数的功能即可。ConvertCharD()要实现的功能是:以行为单位把字符串中的所有小写字母改写成该字母的上一个字母,如果是字母a,则改写成字母z。火写字母仍为大写字母,小写字母仍为小写字母,其他字符不变。最后把已处理的字符串仍按行重新存入字符串数组string中。凶此解答本题的关键在于如何实现字符问的转换。【解题思路】在for循环语中当自变量从0递增到maxline时,就完成了对一篇文章中每一行的字符进行判断。如果字符是a,就用字符z替换,否则如果字符是大于等于字符b,而小于等于字符z的A

28、SCII码值,就对其ASCII码值减1。【知识拓展】字符问的转换可以通过字母的ASCII值来实现,字母的ASCII值比上一个字母的的ASCII大1。【参考答案】【易错分析】判断字符的范围是否大于等于字符b而小于等于字符Z;对于字符a,要单独进行处理。【考点链接】c语言的for循环语句;字符的ASCII码值减1,就是其上一个字符的ASCII码值第1 4套上机考试试题请编写函数countValue(),它的功能是:求出11000之内能被7或11整除但不能同时被7或11整除的所有整数,将它们放在数组a中。并通过n返回这些数的个数。主函数最后调用函数Wdata()把计算结果输出到0UT.dat中。注意

29、:部分源程序已经给出。请勿改动主函数main()和输出数据函数Wdata()的内容。来第1 4套上机考试试题请编写函数countValue(),它的功能是:求出11000之内能被7或11整除但不能同时被7或11整除的所有整数,将它们放在数组a中。并通过n返回这些数的个数。主函数最后调用函数Wdata()把计算结果输出到0UT.dat中。注意:部分源程序已经给出。请勿改动主函数main()和输出数据函数Wdata()的内容。来第14套试题答案及详解【审题分析】分析题目可知,本题只要实现countValue()数的功能即可。countValue()要实现的功能是:求出1到1000之内能被7或11整

30、除但不能同时被7和11整除的所有整数,将它们放在数组a中,并通过n返回这些数的个数。因此解答本题的关键在于如何将一个指定的关系转换为C语言+表达式。【解题思路】这里我们首先在for循环语句中当自变量i从l递增到1000时,对每一个数进行i7=0&i11或i7&i110的逻辑判断,如果其中一个表达式成立,则把数字i输入数组a中,整型指针变量n加1,数组指针a向后移动一位。【参考答案】15 【易错分析】能被7或11整除但不能同时被7和11整除的整数的条件为:i%70&i11或i7&i110,其一定成立即可。【考点链接】求余运算、指针变量的应用第15套上机考试试题已知数据文件IN.dat中存有300

31、个四位数,并已调用读函数Rdata()把这些数存入数a中,请编写函数primeCal(),其功能是:求出这些四位数中素数的个数count,再求出所有满足此条件的四位数的平均值Avel以及不满足此条件的四位数的平均值Ave2。最后调用写函数wdata(),把结果count、Ave1、Ave2输出到OUT.dat文件中。例如,5591是素数,则该数满足条件计算平均值Avel,且个数count=count+1。9812是非素数,则该数不满足条件计算平均值Ave2。注意:部分源程序已经给出。程序中已定义数组a300,已定义变量count、Ave1、Ave2。请勿改动主函数main()、读函数Rdata

32、()和写函数Wdata()的内容。来第15套试题答案及详解【审题分析】分析题目可知,本题只要实现P血neCal()函数的功能即可。PrimeCal()要实现的功能是:求出这些四位数中是素数的个数count,再求出所有满足此条件的四位数的平均值Ave1以及不满足此条件的四位数的平均值Ave2。因此解答本题的关键在于如何判断一个数为素数。【解题思路】在for循环语句中当自变量1递增到299时,对数组a中的每一个元素ai调用函数isP(ai)米判断元素ai是否为素数,如果是素数,则把ai加入Avc1上,count自加;否则把ai加入Ave2上。当退出循环时,用Ave1除以count就得到所有满足此条

33、件的四位数的平均值,用Ave2除以300-count就得到所有不满足此条件的四位数的平均值。 【参考答案】【易错分析】退出for循环时,变量Avel的值是所有满足条件的四位数的和:变量Ave2的值是所有不满足条件的四位数的和。【考点链接】for循环语句、ifelse条件判断语句第16套上机考试试题下列程序的功能是:寻找并输出11-999之间的数m,它满足m、m2和m3均为回文数。所谓回文数是指各位数字左右对称的整数,例如121、676、94249等。满足卜述条件的数如m11,m2121,m31331皆为回文数。请编写函数intpalindromevalue(1ong n)实现功能:如果是回文数

34、,则函数返回1,反之则返凹0。最后,把结果输出到文件OUT.dat中。注意:部分源程序已给出。清勿改动主函数main()的内容。来源第1 6套试题答案及详解【审题分析】分析题目町知,本题只要实现palindromevalue函数的功能即町。函数palindromevalue要实现的功能是:寻找并输出11至999之间的数m,它满足m、m2和m3均为回文数。因此解答本题的关键在于如何判断m是否为回文数。【解题思路】判断数字是否为回文数,只要对比该数字的对立位置上的数是否相等即可。这里我们首先把要判断是否是回文数的数字通过ltoa函数,将其拆分成单个数字,并存入到一个字符数组中,然后从字符数组的开始

35、位置和尾部位置同时向其中间位置逐个字符的进行比较运算。如果首尾位置的两个字符不相等,则退出循环,说明这个数不是回文数。如果比较到中间位置时都相等,则说明这个数字是回文数。【参考答案】【易错分析】字符串尾部指针的自减为-Str,而不是str-。【考点链接】字符串首尾两端字符的相等比较。第17套上机考试试题请补充程序,使得程序能实现以下功能: 从文件IN.dat中读取200个整数至数组number中,求出奇数的个数cnt1和偶数的个数cnt2以及数组number下标为偶数的元素值的算术平均值ave(保留2位小数)。把结果cnt1、cnt2、ave输出到OUT.dat中。注意:部分程序、读数据函数r

36、ead_dat(int number200)及输出格式已给出。来第17套试题答案及详解【审题分析】分析题目可知,本题程序要实现的功能是:从文件IN.dat中读取200个整数至数组number中,求出奇数的个数cnt1和偶数的个数cnt2以及数组number下标为偶数的元素值的算术平均值avc(保留2位小数),而读取数据的程序题中已经给出。冈此只要编写求出数组中奇数的个数和偶数的个数,以及下标为偶数的所有元素的平均值即可。【解题思路】在for循环语句中,对数组number中的每一个元素进行对2求余数,如粜余数等于1则数组元素numberi是奇数,奇数的个数变量cnt1加1,否则偶数的个数变量cn

37、t2加1。如果数组number下标变量i能被2整除,则把数组元数numberi与变量j相加。退出循环后变量i的值除以(N2)得到数组number下标为偶数的元素值的算术平均值,再转换成单精度实数赋给变量ave。【参考答案】【易错分析】在进行求算术平均值的时候,要把求的结果值转化成单精度型数据。【考点链接】求余运算、数据类型的转换。第18套上机考试试题函数Rdata()实现从文件IN.dat中读取一篇英文文章,存入到字符串数组string中,请编写函数CharRigbt0,其功能是:以行为单位把字符串中的最后一个字符的ASCII值右移4位后加倒数第二个字符的ASCII值,得到最后一个新的字符;倒

38、数第一个字符的ASCII值右移4位后加倒数第三个字符的ASCII值,得到倒数第二个新的字符;依此类椎,一直处理到第二个字符;第个字符的ASCII值加原最后一个字符的ASCII值,得到第一个新的字符。得到的新字符分别存放在原字符串对应的位置上,最后已处理的字符串仍按行重新存入字符串数组string中。最后调用函数Wdata(),把结果string输出到文件OUT.dat中。原始数据文件存放的格式是:每行的宽度均小于80个字符(含标点符号和空格)。注意:部分源程序已经给出。请勿改动主函数main()、读函数Rdata()和写函数Wdata()的内容。来第18套试题答案及详解【审题分析】分析题目可知

39、,本题只要实现CharRight()函数的功能即可。CharRight()函数要实现的功能是:按“将字符的ASCII值右移4位并加上该字符前面的一个字符的ASCII值等到新的字符,然后存在原位”的替代关系,将字符串数组string中的字符全部替换。因此解答本题的关键在于读取字符串数组中的字符,然后转换成ASCII码值,最后进行替换运算。【解题思路】这里我们通过for循环语句来实现读取字符串数组中的所有字符。当自变量i从0递增到maxline时,就完成了对一篇文章每一行的扫描。对一行的字符串数组,首先利用字符串函数strlen求出字符串数组stringi的长度输给变量str1,把字符串中的最后一

40、个字符赋给ch;然后在for循环语句中当自变量J从str1-1递减到0时,对每一个字符的ASCII值右移4位,右移4位的字符与其前一个字符相加,两者的和仍然存入字符串数组元素stringij中:最后替换第一个字符时将其ASCII值与ch相加,得到第一个新的字符。【参考答案】【易错分析】字符的ASCII值右移4位,用表达式stringilj4表示。【考点链接】字符的移位运算。第19套上机考试试题已知数据文件IN.dat中存有200个四位数,并已调用读函数rdata()把这些数存入数组a中,请编写函数evenvalue(),其功能是:如果四位数每位上的数字均是0、2、4、6或8,则统计出满足此条件

41、的四位数的个数count,并把这些四位数按从大剑小的顺序存入数组b中。最后main()调用函数wdata(),把结果count以及数组b中符合条件的四位数输出剑OUT.dat义件。注意:部分程序已经给出。程序中已定义数组a200,b200;已定义变量count。请勿改动数据文件IN.dat中的任何数据及主函数main()、读函数rdata()和写函数wdata()中的内容。第19套试题答案及详解【审题分析】分析题目可知,题中需要解决的问题就是实现evenvalue函数的功能问题,而 evenvalue函数的功能是:统计满足“四位数每位上的数字均是0、2、4、6或8”条件的数字个数count,并

42、把这些四位数按从大到小的顺序存入数组b中。因此本题的关键在于如何判断一个四位数的每位数都满足条件,之后就可以通过一个for循环来对这200个数逐个判断。【解题思路】解答本题可分为以下4个步骤:第1步:分解出这个四位数的每位数字。木题用ai除以1000得到ai的千位上的数字,然后存入bbO(这里要定义一个数组bb4);用ai对1000求余数再除以100得到ai百位上的数字存入bb1;用ai对100求余数再除以10得到ai十位上的数字存入bb2;用ai埘10求余得到ai的个位上的数字,然后存入bb3,这样数组bb4就存入了ai的每位上的数字。第2步:判断每位数字是否为“0或2或4或6或8”。这里我

43、们利用循环语句对数组bb4中的各个元素对2求余,如果每个元素的余数为0,则说明该元素的每位数字均是0或2或4或6或8,则设簧flag为1(这里要定义一个变量flag),否则设置flag为0。第3步:将符合条件的数存入数组bcount中。这里只要对flag进行判断即可,即如果flag的值为1,则说明ai符位卜的数字均是0或2或4或6或8。把ai的值赋给数组bcount,变量count加1。在第一个for语句执行完成后,就得到了200个四位数中所有符合条件的四位数。第4步:执行第二个for语句对数组b的各元素进行从大到小的排序即可。【参考答案】【易错分析】利用求余运算得到四位数各位上的数字。【考点链接】求余运算、for循环语句、数组的排序问题第20套上机考试试题函数RData()实现从文件IN.dat中读取一篇英文文章存入字符串数组S

版权声明:以上文章中所选用的图片及文字来源于网络以及用户投稿,由于未联系到知识产权人或未发现有关知识产权的登记,如有知识产权人并不愿意我们使用,如有侵权请立即联系:2622162128@qq.com ,我们立即下架或删除。

Copyright© 2022-2024 www.wodocx.com ,All Rights Reserved |陕ICP备19002583号-1 

陕公网安备 61072602000132号     违法和不良信息举报:0916-4228922