2013年计算机等级考试三级网络技术试题3
4779 点击·0 回帖
![]() | ![]() | |
![]() | 已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量sl(整型)、金额je(长整型)几部分组成。其中,金额=单价×数量可计算得出。函数ReadDat()的功能是读取这100个销售记录并存入数组sell中。请编制函数SortDat(),其功能要求:按金额从大到小进行排列,若金额相同,则按产品名称从小到大进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件OUT.DAT中。 注意:部分源程序已给出。请勿改动主函数main( )、读函数ReadDat( )和写函数WriteDat( )的内容。 【试题程序】 #include <stdio.h> #include <memory.h> #include <string.h> #include <stdlib.h> #define MAX 100 typedef struct { char dm[5]; char mc[11]; int dj; int sl; long je; } PRO; PRO sell[MAX]; void ReadDat(); void WriteDat(); void SortDat() { } void main() { memset(sell,0,sizeof(sell)); ReadDat(); SortDat(); WriteDat(); } void ReadDat() { FILE *fp; char str[80],ch[11]; int i; fp=fopen("IN.DAT","r"); for(i=0;i<100;i++) { fgets(str,80,fp); memcpy(sell.dm,str,4); memcpy(sell.mc,str+4,10); memcpy(ch,str+14, 4); ch[4]=0; sell.dj=atoi(ch); memcpy(ch,str+18,5); ch[5]=0; sell.sl=atoi(ch); sell.je=(long)sell.dj*sell.sl; } fclose(fp); } void WriteDat() { FILE *fp; int i; fp=fopen("OUT.DAT","w"); for(i=0;i<100;i++) { fprintf(fp,"%s %s %4d %5d %10ldn",sell.dm, sell.mc, sell.dj,sell.sl, sell.je); } fclose(fp); } | |
![]() | ![]() |