7:已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位),产品名称mc(字符型10位),单价dj(整型),数量sl(整型),金额je(长整型)四部分组成。其中:金额=单价*数量计算得出。函数ReadDat()是读取这100个销售记录并存入结构数组sell中。请编制函数SortDat(),其功能要求:按产品代码从大到小进行排列,若产品代码相同,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件OUT10.DAT中。
注意: 部分源程序存放在PROG1.C中。
请勿改动主函数main( )、读数据函数ReadDat()和输出数据函数WriteDat()的内容。
----------------------------------
void SortDat()
{
int I,j;
PRO xy; /*PRO为一已定义的结构体*/
for(I=0;I<99;I++) /*100个数循环*/
for(j=I+1;j<100;j++) /*同样是100个数循环,但较前一个后置一位*/
if(strcmp(sell[I].dm,sell[j].dm)<0) /* strcmp: 比较字符串s1和s2。
说明:
当s1<s2时,返回值<0
当s1=s2时,返回值=0
当s1>s2时,返回值>0
*/
{
xy=sell[I];
sell[I]=sell[j]; /*经典方法*/
sell[j]=xy;
}
else if(strcmp(sell[I].dm,sell[j].dm)==0)
if(sell[I].je<sell[j].je) /*注意,这里没有用到 strcmp 是因为 je是长整型的数据类型*/
{
xy=sell[I];
sell[I]=sell[j];
sell[j]=xy;
}
}