一个关于文件结构体数组的条件排序函数

已知在文件IN2.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量sl(整型)、金额je(长整型)五部分组成。其中:金额=单价×数量。函数ReadDat()的功能是读取这100个销售记录并存入结构数组sell中。请编制函数SortDat(),其功能要求:按产品名称从大到小进行排列,若产品名称相同,则按金额从小到大进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件OUT2.DAT中。


#include  <stdio.h>
#include  <memory.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()
{
	int i,j;
	PRO xy;
	for(i=0;i<MAX;i++)
		for(j=i+1;j<MAX;j++)
		{
			if(strcmp(sell[i].mc,sell[j].mc)<0)
			{
				
				xy=sell[i];
				sell[i]=sell[j];
				sell[j]=xy;
			}
			else if(strcmp(sell[i].mc,sell[j].mc)==0)
			{
				sell[i].je=sell[i].dj*sell[i].sl;
				sell[j].je=sell[j].dj*sell[j].sl;
				if(sell[i].je > sell[j].je)
				{	
					xy=sell[i];
					sell[i]=sell[j];
					sell[j]=xy;
				}
			}
		}


}
void main()
{
  memset(sell,0,sizeof(sell));
  ReadDat();
  SortDat();
  WriteDat();
}
void ReadDat()
{
  FILE *fp;
  char str[80],ch[11];
  int i;
  fp=fopen("IN2.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("OUT2.DAT","w");
  for(i=0;i<100;i++)
     fprintf(fp,"%s %s %4d %5d %10ld\n",sell[i].dm,sell[i].mc,sell[i].dj,sell[i].sl,
sell[i].je);
  fclose(fp);
}

 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值