[计算机类试卷]国家三级(数据库技术)机试模拟试卷78及答案与解析.doc

上传人:周芸 文档编号:495355 上传时间:2018-11-28 格式:DOC 页数:4 大小:27.50KB
下载 相关 举报
[计算机类试卷]国家三级(数据库技术)机试模拟试卷78及答案与解析.doc_第1页
第1页 / 共4页
[计算机类试卷]国家三级(数据库技术)机试模拟试卷78及答案与解析.doc_第2页
第2页 / 共4页
[计算机类试卷]国家三级(数据库技术)机试模拟试卷78及答案与解析.doc_第3页
第3页 / 共4页
[计算机类试卷]国家三级(数据库技术)机试模拟试卷78及答案与解析.doc_第4页
第4页 / 共4页
亲,该文档总共4页,全部预览完了,如果喜欢就下载吧!
资源描述

1、国家三级(数据库技术)机试模拟试卷 78及答案与解析 一、程序设计题 1 已知数据文件 IN78.DAT中存有 200个 4位数,并己调用读函数 readDat()把这些数存入数组 a中,请编制一函数 jsVal(),其功能是:如果一个 4位数的千位数字上的值大于等于百位数字上的值,百位数字上的值大于等于十位数字上的值,以及十位数字上的值大于等于个位数字上的值,并且此 4位数是奇数,则统计出满足此条件的数的个数 cnt并把这些 4位数按从小到大的顺序存入数组 b中,最后调用写函数 writeDat()把结果 cnt及数组 b中符 合条件的 4位数输出到 OUT78.DAT文件中。 注意:部分源

2、程序已给出。 程序中已定义数组: a200, b200,已定义变量: cnt。 请勿改动主函数 main()、读函数 readDat()和写函数 writeDat()的内容。 试题程序: #include stdio. h #define MAX 200 int aMAX,bMAX,cnt=0; void jsVal( ) void readDat( ) int i; FILE *fp; fp=fopen(“IN78.DAT“,“r“); for(i=0;i MAX ;i+) fscanf(fp, “%d“ , fclose(fp); main() int i; readDat ( ); js

3、Val (); printf (“满足条件的数 =%dn“, cnt); for(i=0;i cnt ;i+) printf(“%d“ ,bi); printf(“n“); writeDat (); writeDat () FILE *fp; int i; fp=fopen(“OUT78.DAT“,“w“); fprintf(fp, “%dn“ ,cnt); for(i=0;i cnt ;i+) fprintf(fp, “%dn“ ,bi); fclose(fp); 国家三级(数据库技术)机试模拟试卷 78答案与解析 一、程序设计题 1 【正确答案】 void jsVal( ) int i,

4、thou, hun, ten, data, j; for (i=0; i MAX ;i+) thou=a i/1000; /*求四位数的千位数字 */ hun=a i %1000/100; /*求四位数的百位数字 */ ten=a i %100/10; /*求四位数的十位数字 */ data=a i %10; /*求四位数的个位数字 */ if (thou =hun) /* 则将满足条件的数存入数组 b中 */ cnt+; /*统计满足条件的数的个数 */ for (i = 0; i cnt - 1; i + ) /*将数组 b中的数按从小到大的顺序排列 */ for (j=i+1; j cn

5、t; j+) if (bibj) data=b i; b i=bj; b j=data; 【试题解析】 本题考查的知识点如下: (1)将一个 4位整数各位上的数转变成单独的数。 (2)判断结构中多个条件的布尔运算。 (3)数据的排序。 在本题中,首先要将一个 4位数的千位、百位、十位、个位拆成独 立的数字。这里借助特殊运算符号 “%”( 取余 )和 “/”(整除 )。将一个 4位数整除 1000则可得到其千位上的数字,除以 1000取余再整除 100则可得百位上的数字,除以 100取余再整除 10则可得十位上的数字,除以 10取余则得个位上的数字。若一个数除以 2取余为 1,则这个数是奇数。题目中的所有条件必须同时满足,所以各条件之间用“与 ”运算。先将满足条件的数存入数组 b中,再对数组中的数据进行排序。最后的排序采用 “选择排序法 ”。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 考试资料 > 职业资格

copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1