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

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