[计算机类试卷]计算机三级网络技术机试(上机操作)模拟试卷60及答案与解析.doc
-
资源ID:505723
资源大小:27.50KB
全文页数:4页
- 资源格式: DOC
下载积分:2000积分
快捷下载

账号登录下载
微信登录下载
下载资源需要2000积分(如需开发票,请勿充值!)
友情提示
2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
|
[计算机类试卷]计算机三级网络技术机试(上机操作)模拟试卷60及答案与解析.doc
1、计算机三级网络技术机试(上机操作)模拟试卷 60及答案与解析 一、程序设计题 1 已知在文件 IN DAT中存有 100个产品销售记录,每个产品销售记录由产品代码 dm(字符型 4位 )、产品名称 mc(字符型 10位 )、单价 dj(整型 )、数量 s1(整型 )、金额 je(长整型 )托部分组成,其中:金额 =单价 *数量计算得出。函数 ReadData()是读取这 100个销售记录并存入结构数组 sell中。请编制函数 SortData(),其功能要求:按产品名称从大到小进行排列,若产品名称相等,则按金额从大到小进行排列,最终排列结构仍 存入结构数组 sell中,最后调用函数 Write
2、Data()把结构输出到文件 OUT5 DAT中。 注意:部分源程序已给出如下; 请勿改动主函数 main()、读数据函数 ReadData()和输出数据函数 WriteData()的内容。 试题程序: #include #include #include #include #define MAX 100 typedef struct char dm5;产品代码 char mc11;产品名称 int dj;单价 int Sl;数量 long je;金额 PRO; PRO sellMAX; void ReadData(); void WriteData(); void SortData() vo
3、id main() memset(sell, 0, sizeof(sell); ReadData(); SortData(); WriteData(); void ReadData() FILE*fp; char str80, ch11; int i; fp=fopen(“IN DAT”, “r”); for(i=0; iMAX; i+) fgets(str, 80, fp); memcpy(selli dm, str, 4); memcpy(selli mc, str+4, 10); memcpy(ch, str+14, 4); ch4= 0; selli dj=atoi(ch); memc
4、py(ch, str+18, 4); eh4= 0; selli s1=atoi(ch); selli je=(1ong)selli dj*selli sl; fclose(fp); void WriteDat() FILE*fp; int i; fp=fopen(“OUT5 DAT”, “W”); for(i=0; iMAX; i+) printf(“ s s 4d 5d 51d n”, selli dm, selli ine, selli dj, selli sl, selli je); fprintf(fp, “ s S 4d 5d 51d n”, sell |J dm。 selli m
5、e, selli dj, selli sl, selli je); fclose(fp); 计算机三级网络技术机试(上机操作)模拟试卷 60答案与解析 一、程序设计题 1 【正确答案】 Void SortData() int i, j; PRO xy; for(i=0; iMAX-1; i+) for(j=i+1; jMAX; j+) if(strcmp(selli mC sellj mc)0 如果产品 i的产品名称小于产品 j的产品名称 (strcmp(selli mc, sellj mc)=0 如果产品 i的产品名称等于产品 j的产品名称 selli jeselli je) 如果产品 i的金额小于产品 j的金额 memcpy( xy, selli, sizeof(xy); memcpy( selli, sellj, sizeof(xy); memcpy( sellj, temp, sizeof(temp); 产品 i和 产品 j交换 【试题解析】 本题主要考查数组的排序操作。 算法思路: i结点与后面的所有 j结点比较,若符合条件则交换 i、 j结点位置。 然后后移结点,执行步骤 直到结点 i是倒数第二结点为止。