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

admin2020-11-19  36

问题 文件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 100
    typedef struct
    {
    char IDES];//产品代码
    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),
    memcpy(ch,str+14,4);
    ch[4]=’\0’;
    sell.price=atoi(eh);
    memcpy(ch.str+18,4);
    ch[4]=’\0’;
    sell.amount=atoi(eh);
    sell.value=(10ng)sell.price*sell.a
    mount;
    }
    fclose(fp);
    }
    void WriteData()
    {
    FILE*fp;
    int i;
    fp=fopen(“OUT.DAT”,“W”);
    for(i=0;i    {
    printf(“%s%s%4d%5d%lOld\n”,sell
    ID,sell.name,sell.price,sell.amount,
    sell.value);
    fprintf(fp,“%S%s%4d%5d%101d\n”,sell
    [r].ID,sell Eli.name,sell[|].price,sell.a
    mount,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;i0 || (strcmp(sell[i].ID.sell[j].ID)==0&&sell [i].valuedsell[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://jikaoti.com/ti/i0s7FFFM
0

最新回复(0)