问答题
                                     已知在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<string.h>
  #include<conio.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 SertDat()
  
  
  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[i].dm,Str,4);
  memcpy(sell[i].mc,str+4,10);
  memcpy(ch,str+14,4);
  ch[4]=0;
  sell[i].dj=atoi(ch);
  memcpy(ch,str+18,5);
  ch[5]=0;
  sell[i].sl=atoi(ch);
  sell[i].je=(long)sell[i].dj*sell[i].sl;
  
  fclose(fp);
  
  void WriteDat(void)
  
  FILE *fp;
  int i;
  fp=fopen("OUT.DAT","w");
  for(i=0;i<100;i++)
  
  printf("%s%s%4d%5d%5d\n",
  sell[i].dm,sell[i].mc,sell[i].dj,sell[i].sl,sell[i].je);
  fprintf(fp,"%s%s%4d%5d%5d\n",
  sell[i].dm,sell[i].mc,sell[i].dj,sell[i].sl,sell[i].je);
  
  fclose(fp);
                                
                                            【参考答案】
                                            
                                            
void SortDat ()
int i,j;
PRO xy;
/*对数组sell的所有......
(↓↓↓ 点击下方‘点击查看答案’看完整答案 ↓↓↓)