首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
已知在文件IN54.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量s1(整型)、金额je(长整型)几部分组成。其中,余额=单价×数量可计算得出。函数ReadDat()的功
已知在文件IN54.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量s1(整型)、金额je(长整型)几部分组成。其中,余额=单价×数量可计算得出。函数ReadDat()的功
admin
2009-02-24
24
问题
已知在文件IN54.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量s1(整型)、金额je(长整型)几部分组成。其中,余额=单价×数量可计算得出。函数ReadDat()的功能是读取这100个销售记录并存入数组sell中。请编制函数 SortDat(),其功能要求:按金额从大到小进行排列,若金额相同,则按产品名称从小到大进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件OUT54.DAT中。
注意:部分源程序已给出。
请勿改动主函数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[MAXI;
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("IN54.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("OUT54.DAT","w");
for(i=0;i<100;i++)
{
fprintf(fp,"%s %s %4d %5d %101d\n",sell
.dm, sell
.mc,
sell
.dj,sell
.sl, sell
.je);
}
fclose(fp);
}
选项
答案
void SortDat() { int i,j; PRO xy; for (i=0;i<99; i++) for (j=i+l; j<100; j++) { if (sell [i] . je<sell [j] . je) /*按金额从大到小进行排列*/ { xy=sell [i]; sell Iii =sell [j]; sell [j] =xy; } else if (sell[i].je==sell[j] .je) /*若金额相同,则按产品名称从小到大进行排列*/ if (strcmp (sell Iii .mc, sell [j ] .mc) >0) { xy=sell Ii]; sell[i]=sell[j]; sell [j] =xy; } } }
解析
本题考查的知识点如下:
(1)结构体及结构数组的相关操作。
(2)结构数组的排序。
(3)字符型数组的比较。
本题着重考查结构体变量的访问、赋值,包括结构体本身及结构体中各个成员的访问和赋值。根据题意要求,我们首先要按照金额对记录从大到小进行排列。若金额相同,则要比较产品名称。因为产品名称为字符型,所以不能使用简单的比较运算符进行比较。在这里,我们使用了字符串处理函数strcmp(char *strll,char*strl2,unsigned int cout)对其进行比较。因为已定义了结构数组,就可以使用循环进行比较排序。排序采用前面介绍的“选择排序法”。
转载请注明原文地址:https://kaotiyun.com/show/YRYZ777K
本试题收录于:
三级网络技术题库NCRE全国计算机三级分类
0
三级网络技术
NCRE全国计算机三级
相关试题推荐
下列关于E-R模型向关系模型转换的叙述中,不正确的是()。
数据库管理系统是位于用户和【】系统之间的一个数据管理软件。
下列关于E-R模型向关系数据模型转换的叙述中,正确的是
在Internet中计算机之间直接利用IP地址进行寻址,因而需要将用户提供的主机名转换成IP地址,这个过程称为域名解析。Internet域名解析有【】和反复解析两种方式。
对关系模式进行规范化的目的是减少数据冗余,并避免出现【】、【】和【】。
下面列出的数据模型中,哪一种是数据库系统中最早出现的数据模型
可变分区存储管理方案中,在空闲区表中选择能满足进程内存要求的最大空闲区,分割后分配的算法是
下面页面淘汰算法中,会产生Belady(异常)现象的是______。
关系模型是数据库系统最常用的一种数据模型。下列关于关系模型的说法,错误的是()
在UML模型中,用于表达一系列的对象、对象之间的联系以及对象间发送和接收消息的图是【15】。
随机试题
产业资本的循环运动【】
X线在传播时,突出表现的性质是
工程项目设计质量管理的总要求是()。
劳动力不均衡系数的正确表述是()。
微型计算机的主机由()构成。
甲股份有限公司(以下简称甲公司)于2019年2月1日召开董事会会议,该次会议召开情况及讨论决议事项如下:(1)甲公司董事会的7名董事中有6名出席该次会议。其中,董事谢某因病不能出席会议。电话委托董事李某代为出席会议并行使表决权。(2)甲公司与乙公司有业
汉魏六朝以乐府民歌闻名,()合称为乐府双璧。
蛹:蝶()
已有定义int(*q)(),指针q可以()。
Wheredoestheannouncementtakeplace?
最新回复
(
0
)