1、计算机三级(网络技术)上机考试 18 及答案解析(总分:-1.00,做题时间:90 分钟)1.已知在文件 IN6.DAT 中存有 100 个产品销售记录,每个产品销售记录由产品代码 dm(字符型 4 位)、产品名称 mc(字符型 10 位)、单价 dj(整型)、数量 sl(整型)、金额 je(长整型)几部分组成。其中:金额=单价数量。函数 ReadDat()的功能是读取这 100 个销售记录并存入结构数组 sell 中。请编制函数 SortDat(),其功能要求:按产品名称从小到大进行排列,若产品名称相同,则按金额从小到大进行排列,最终排列结果仍存入结构数组 sell 中,最后调用函数 Wri
2、teDat()把结果输出到文件 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 sell MAX; void ReadDat(); voi
3、d WriteDat(); void SortDat() main() memset(sell, 0, sizeof(sell); ReadDat(); SortDat(); WriteDat(); void ReadDat() FILE *fp; char str80, ch11; int i; fp = fopen(“IN6.DAT“, “r“); for (i = 0; i sellj.je) /*则按金额从小到大进行排列*/ xy=selli;selli=sellj;sellj=xy; )解析:本题是有关结构体数组的排序问题,可以用选择法来实现。用第一个元素的产品名称依次和它后面的元素的产品名称进行比较,如果发现当前元素的产品名称比后面的某个元素的产品名称对应字符的ASCII 码大(这里用到了字符串比较函数 strcmp()),则交换这两个元素的位置,继续和后面的其他元素进行比较,最终在第一个元素中存放的是产品名称最小的元素。以此类推,就实现了从小到大排序的功能。注意:这里要进行交换的是两个结构体变量,而不是它们的某一个域,因此,要借助第三个结构体变量来充当中间容器。若产品名称相同,则要按照金额从小到大进行排序。