2006年9月全國等級考試三級c語言上機題庫(十二)

★題目12(無憂id 78結構體運算題題)

 

已知在檔案in.dat中存有100個產品銷售記錄,每個產品銷售記錄由產品代碼dm(字元型4位),產品名稱mc(字元型10位),單價dj(整型),數量sl(整型),金額je(長整型)五部分組成。其中:金額=單價*數量計算得出。函式readdat()是讀取這100個銷售記錄並存入結構數組sell中。請編制函式sortdat(),其功能要求:

按產品名稱從小到大進行排列,若產品名稱相等,則按金額從小到大進行排列,最終排列結果仍存入結構數組sell中,最後調用函式writedat()把結果輸出到檔案out5.dat中。

部分源程式存在檔案prog1.c中。

請勿改動主函式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()

{int i,j;

pro xy;

for(i=0;i<99;i++)

for(j=i+1;j<100;j++)

if(strcmp(sell[i].mc,sell[j].mc)>0||strcmp(sell[i].mc,sell[j].mc)==0&&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("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()

{

file *fp;

int i;

 

fp=fopen("out5.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);

}