文件IN.DAT中存有200个销售记录,每个记录均由产品代码ID(字符型4位)、产品名称name(字符型10位)、单价price(整型)、数量amount(整型)、金额value(长整型)几部分组成。其中;金额一单价×数量,函数readData()负责将I

admin2012-07-20  51

问题 文件IN.DAT中存有200个销售记录,每个记录均由产品代码ID(字符型4位)、产品名称name(字符型10位)、单价price(整型)、数量amount(整型)、金额value(长整型)几部分组成。其中;金额一单价×数量,函数readData()负责将IN.DAT中的数据读到结构数组sell[]中。请编制函数sortData(),将各个记录按产品名称从大到小进行排列,若产品名称相同,则按金额从小到大进行排列,并将排列后的结果存放到sell[]中。函数writeData()负责将sell[]中的数据输出到文件OUT.DAT中。
注意;部分源程序已给出。
请勿改动主函数main()、读函数readData()和写函数writeData()的内容。
试题程序;
#include
#include
#include
#include
#define MAX 200
typedef struct
{
  char ID[5];//产品代码
  char name[11];//产品名称
  int price;  //单价
  int amount;  //数量
  long value;  //金额
}
PRODUCT;
PRODUCT sell[MAX];
void readData();
void writeData();
void sortData()
{
}
void readData()
{
  FILE*fp;
  char str[80],ch[11];
  int i;
  fp=fopen("IN.DAT","r");
  for(i=0;i  {
    fgets(str,80,fp);
    memcpy(sell.ID,str,4);
    memcpy(sell.name,str+4,10);
    memepy(ch,str+14,4);ch[4]=’\0’;
    sell.price=atoi(ch);
    memcpy(ch,str+18,4);ch[4]=’\0’;
    sell.amount=atoi(ch);
    sell[,i].value=(long)sell.price*sell[,i].amount;
    }
  fclose(fp);
}
void writeData()
{
  FILE*fp;
  int i;
fp=fopen("OUT.DAT","W");
for(i=0;i{
  printf("%s%s%4d%4d%101d\n",sell.ID,sell.name,sell.price,sell.amount,sell.value);
  fprintf(fp,"%s %s%4d%4d %101d\n",sell.ID,sell.name,sell.price,sell.amount,sell.value);
}
  fclose(fp);
}
void main()
{
  memset(sell,0,sizeof(sell));
  readData();
  sortData();
  writeData();
}

选项

答案 void sortData() { PRODUCT temp; int i,j; memset(&temp,0,sizeof(temp)); for(i=0;isell[j].value)) { memcpy(&temp,&sell[i],sizeof(temp)); /*将以&sell[i]为起始地址、大小为sizeof(temp) 的内存中的内容复制到以&.temp为起始地址的内存中*/ memcpy(&sell[i],&.sell[j],sizeof(temp)); memcpy(&.sell[j],&temp,sizeof(temp)); } }

解析 本题考查的主要是结构数组排序的问题。所谓结构数组排序就是以结构中某一元素为依据对结构数组进行排序。本题排序的思想是;将当前数据与其后的各个数据相比较,如果当前数据比其后的数据小,则将两数据进行交换,从而使得前面的数据大于后面的数据,达到从大到小排序的目的。但是由于结构不像变量那样可以通过简单的赋值来交换变量(如果要赋值的话需要对结构里的所有元素进行赋值替换,比较麻烦),所以在进行两个相邻结构交换时,要用到内存拷贝函数memcpy()来对内存的内容整体进行操作。
转载请注明原文地址:https://kaotiyun.com/show/m24Z777K
0

最新回复(0)