首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
已知在文件IN54.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量sl(整型)、金je(长整型)几部分组成。其中,金额=单价×数量可计算得出。函数ReadDat()的功能
已知在文件IN54.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量sl(整型)、金je(长整型)几部分组成。其中,金额=单价×数量可计算得出。函数ReadDat()的功能
admin
2009-02-15
60
问题
已知在文件IN54.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量sl(整型)、金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[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("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+1; j<100; j++) { if (sell [i]. je<sell [j]. je) /*按金额从大到小进行排列*/ { xy=sell [i]; sell [i]=sell [j]; sell [j]=xy; } else if (sell[i].je==sell[j].je) /*若金额相同,则按产品名称从小到大进行排列*/ if (strcmp (sell [i] .mc, sell [j].mc) >0) { xy=sell [i]; sell [i]=sell [j]; sell [j]=xy; } } }
解析
本题考查的知识点如下:
(1)结构体及结构数组的相关操作。
(1)结构数组的排序。
(3)字符型数组的比较。
本题着重考查结构体变量的访问、赋值,包括结构体本身及结构体中各个成员的访问和赋值。根据题意要求,我们首先要按照金额对记录从大到小进行排列。若金额相同,则要比较产品名称。因为产品名称为字符型,所以不能使用简单的比较运算符进行比较。在这里,我们使用了字符串处理函数sbcmp(char*strll,chaf*str12,unsigned int cout对其进行比较。因为已定义了结构数组,就可以使用循环进行比较排序。排序采用前面介绍的“选择排序法”。
转载请注明原文地址:https://www.kaotiyun.com/show/iXfZ777K
本试题收录于:
三级信息管理技术题库NCRE全国计算机三级分类
0
三级信息管理技术
NCRE全国计算机三级
相关试题推荐
()是路由器通过路径选择算法为网络上的路径产生一个数字。
复合型病毒指具有()和()两种寄生方式的计算机病毒。
()指能够寄生在文件中的计算机病毒。这类病毒程序感染可执行文件或数据文件。
在Internet中,对网络的攻击可以分为服务攻击与()2种基本类型。
根据备份服务器在备份过程中是否可以接收用户响应和数据更新,又分为()备份和()备份。
______由两个及两个以上建筑物的电话、数据、电视系统组成一个建筑群综合布线系统。
交换式局域网增加带宽的方法是在交换机多个端口之间建立______。
路由器网络管理能力不可以管理到()。
将Catalyst6500交换机的设备管理地址设置为204.106.1.10/24的正确配置语句是______。
以下列出了IM系统与其开发公司的对应关系,正确的是()。
随机试题
Theoldladyhasnever______thehousesinceshemovedin.
癫痫发作的特点不包括
血栓闭塞性脉管炎的病变部位
在会计电算化方式下,错账的更正方法不包括()。
商业银行信息系统包括主要面向客户的业务处理系统和主要供内部管理使用的管理信息系统。在操作风险管理中,信息系统的主要作用包括()。
若圆C经过坐标原点和点(4,0),且与直线y=1相切,则圆C的方程是__________.
张、王、李、赵四人进入乒乓球的半决赛。甲、乙、丙、丁四位教练对半决赛结果有如下预测:甲:小张未进决赛,除非小李进决赛。乙:小张进决赛,小李未进决赛。丙:如果小王进决赛,则小赵未进决赛。丁:小王和小李都未进决赛。
有16朵花上共落有27只蜜蜂,每朵花上落了1只,2只或者3只蜜蜂,其中落有1只蜜蜂的花朵数与落有2只和3只蜜蜂的花朵总数一样多,那么,落了2只蜜蜂的花有()朵。
设总体X服从参数为λ(λ>0)的泊松分布,X1,X2,…,Xn(n≥2)为取自总体的简单随机样本,则对应的统计量T1=有()
在传统的集合运算中,关系R和关系S的差的结果可表示为(t表示元组)【】。
最新回复
(
0
)