首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量sl(整型)、金额je(长整型)五部分组成。其中;金额一单价*数量计算得出。函数ReadDat()是读取lO
已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量sl(整型)、金额je(长整型)五部分组成。其中;金额一单价*数量计算得出。函数ReadDat()是读取lO
admin
2012-07-20
37
问题
已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量sl(整型)、金额je(长整型)五部分组成。其中;金额一单价*数量计算得出。函数ReadDat()是读取lOO个销售记录并存人结构数组sell中。请编制函数SortDat(),其功能要求;按金额从小到大进行排列,若金额相等,则按产品代码从小到大进行排列,最终结果仍存入结构数组sell中,最后调用函数WriteDat()把结构输出到文件OUTl.DAT中。
注意;部分源程序已给出。
请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。
试题程序;
#include
#include
#include
#include
#define MAX 100
typedef struct
{
char dm[5];//产品代码
char me[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,4);ch[4]=0;
sell
.sl=atoi(ch);
sell
.je=(10ng)sell
.dj*sell
.sl;
}
fclose(fp);
}
void WriteDat()
{
FILE*fp;
int i;
fp=fopen("OUTl.DAT","w");
for(i=0;i<100;i++)
{
printf("%s%s%4d%5d%51d\n",sell
.dm,sell
.mc,sell
.dj,sell
. sl,sell
.je);
fprintf(fP,"%s%s % 4d%5d%51d\n",sell
.dm,sell
.mc,sell
.dj,sell
.sl,sell
.je);
}
fclose(fp);
}
选项
答案
int i,j; PR0 xy; for(i=0;i<99;i++) for(j=i+1;j<100;j++) if(sell[i].je>sell[j].je //如果产品i的金额大于产品j的金额 ||(sell[i].je==sell[j].je //如果产品i的金额等于产品j的金额 &&strcmp(sell[i].dm,sell[j].dm)>0)) //如果产品i的产品代码大于产品j的产品代码 {memcpy(&xy,&sell[i],size of(xy)); memcpy(&sell[i],&sell[i],size of(xy)); memcpy(&xy,&sell[i],size of(xy));}//产品i和产品j交换
解析
本题主要考查数组的排序操作。算法思路;1.结点与后面的所有j结点比较,若符合条件则交换i、j结点位置。2.然后后移i结点,执行步骤1直到i结点是倒数第二结点为止。
转载请注明原文地址:https://kaotiyun.com/show/S24Z777K
本试题收录于:
三级网络技术题库NCRE全国计算机三级分类
0
三级网络技术
NCRE全国计算机三级
相关试题推荐
实现不同网络协议之间转换的设备是______。
下面的四个IP地址,属于D类地址的是______。
如果发送者利用自己的私钥对要传送的数据实现加密,接收者以发送者的公钥对数据进行解密,这种技术能够实现______。
网桥运行在______。
常用的电子支付方式包括电子现金、【 】和电子支票。
防火墙自身有一些限制,它不能阻止Ⅰ.外部攻击Ⅱ.内部威胁Ⅲ.病毒感染
在令牌总线和令牌环局域网中,令牌是用来控制结点对总线的
决定使用哪条路径通过子网,应属于下列OSI的哪一层处理?
目前,保证电子邮件安全的方式是使用【 】。
NetWare文件系统的目录与文件建立在
随机试题
质量管理体系在GB/T19000—2008/ISO9000—2005中的定义为“是质量方面指挥和控制组织的管理体系”。质量管理体系是把下列哪些因素都综合在一起,在质量方针的指引下,为达到质量目标而不断自我完善、改进和提高的一个有机系统
认为随着公司债权资本的增加,债权人的监督成本随之提升,债权人会要求更高的利率的是()。
在汉朝以前,史书上关于蹴鞠的记载只有零星碎片,但是从中不难看出,蹴鞠至少起源于春秋战国时代,而且兼具娱乐和锻炼的性质,并且在此后的数千年中,蹴鞠一直兼具这两种性质。到了汉代,蹴鞠得到快速发展。最先对蹴鞠的发展起到关键作用的人物,是刘邦的父亲刘太公。刘邦称帝
博物馆内部的整体性与多样性,促使人们审视当今时代人类生存问题的整体性与多样性。在普世性与在世性之间,在群与我之间,博物馆要把握好那个度、那个边界。博物馆既要不断丰富自己的藏品与内涵,又要禁止破坏和伤害;既要以博物馆化的胸怀去迎接日益丰富的物质与精神生活,又
注意事项1.本题本由给定资料与作答要求两部分构成。考试时限为150分钟。其中,阅读给定资料参考时限为40分钟,作答参考时限为110分钟。满分150分。2.监考人员宣布考试开始时,你才可以开始答题。3.请在题本、答题卡指定位置填
下列哪项行为属于行政行为?()
巴黎公社时期(1871)的革命报刊有何特点?其在新闻领域方面最重要的历史教训是什么?
下图是校园网某台主机在命令行模式下执行某个命令时用sniffer捕获的数据包。请根据图中信息回答下列问题。图中的①和②删除了部分显示信息,其中①处的信息应该是【17】,②处的信息应该是【18】。
生育率
TheAmazonMystery:WhatAmerica’sStrangestTechCompanyIsReallyUpToA)Ifthere’sasentencethatsumsupAmazon,the
最新回复
(
0
)