灯火互联
管理员
管理员
  • 注册日期2011-07-27
  • 发帖数41778
  • QQ
  • 火币41290枚
  • 粉丝1086
  • 关注100
  • 终身成就奖
  • 最爱沙发
  • 忠实会员
  • 灌水天才奖
  • 贴图大师奖
  • 原创先锋奖
  • 特殊贡献奖
  • 宣传大使奖
  • 优秀斑竹奖
  • 社区明星
阅读:7104回复:0

[三级考试]2013年计算机等级考试三级网络技术试题1

楼主#
更多 发布于:2013-02-21 13:22

已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量sl(整型)、金额je(长整型)几部分组成。其中,金额=单价×数量可计算得出。函数ReadDat()的功能是读取这100个销售记录并存入数组sell中。请编制函数SortDat(),其功能要求:按金额从大到小进行排列,若金额相同,则按产品代码从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用写函数WriteDat()把结果输出到文件OUT.DAT中。
注意:部分源程序已给出。请勿改动主函数main( )、读函数ReadDat( )和写函数WriteDat( )的内容。
【试题程序】
#include <stdio.h>
#include <memory.h>

#include <stdio.h>
#include <memory.h>
#include <string.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()
{

}
 
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.dm,str,4);
    memcpy(sell.mc,str+4,10);
    memcpy(ch,str+14, 4);
    ch[4]=0;

    sell.dj=atoi(ch);
    memcpy(ch,str+18,5);
    ch[5]=0;
    sell.sl=atoi(ch);
    sell.je=(long)sell.dj*sell.sl;
  }
  fclose(fp);
}

void WriteDat()
{
  FILE *fp;
  int i;
  fp=fopen("OUT.DAT","w");
  for(i=0;i<100;i++)
  {
  fprintf(fp,"%s  %s  %4d %5d%10ldn",sell.dm,sell.mc,sell.dj,sell.sl,sell.je);
  }
  fclose(fp);
}

喜欢0 评分0
游客

返回顶部