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

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

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

已知文件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 <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
游客

返回顶部