问答题
                                     已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量sl(整型)、金额je(长整型)5部分组成。其中:金额=单价×数量。函数ReadDat()读取这100个销售记录并存入结构数组sell中。请编制函数SortDat(),其功能要求:按产品代码从大到小进行排列,若产品代码相同,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件OUT10.DAT中。
  部分程序已经给出。
  请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。
  #include <stdio.h>
  #include <mem.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 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[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("OUT10.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;
for(i=......
(↓↓↓ 点击下方‘点击查看答案’看完整答案、解析 ↓↓↓)