首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录南产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数最s1(整型)、金额je(长整型)五部分组成。其中:金额=单价*数量计算得出。函数ReadDat()是读取10
已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录南产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数最s1(整型)、金额je(长整型)五部分组成。其中:金额=单价*数量计算得出。函数ReadDat()是读取10
admin
2021-06-16
43
问题
已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录南产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数最s1(整型)、金额je(长整型)五部分组成。其中:金额=单价*数量计算得出。函数ReadDat()是读取100个销售记录并存入结构数组sell中。请编制函数SortDat(),其功能要求:按金额从小到大进行排列。若金额相等,则按产品代码从小到大进行排列,最终结果仍存人结构数组sell中,最后调用函数WriteDat()把结构输出到文件OUT1.DAT中。
注意:部分源程序已给出。
请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。
试题程序:
#include
#include
#include
#include
#define MAX 100
typedef struct
{
char dm[5];//产品代码
char mc[11];//产品名称
int dj;//单价
int s1;//数量
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;
sellEi].dj=atoi(ch);
memcpy(ch,str+18,4);ch[4]=0;
sell
.sl=atoi(ch);
sell
.je=(10ng)sell
.dj*sellEi].s1;
}
fclose(fp);
}
void WriteDat()
{
FILE*fp;
int i;
fp=fopen(“OUT1.DAT“,“W”);
for(i=0;i<100;i++)
{
printf(“%s%s%4d%5d%51d\n”,sell
.
dm,sell
.mc,sellEi].dj,sell
.sl,sell
.je);
fprintf(fp,“%S%S%4d%5d%51d\n”.sell
.dm,sell
.mC.sell
.dj,sell
.s1,sell
.
je);
}
fclose(fp);
}
选项
答案
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 //如果产品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)); memepy(&sell[i],&sell[i],size of(xy)); memepy(&xy,&sell[i],size of(xy));) //产品i和产品j交换
解析
本题主要考查数组的排序操作。
算法思路:①结点与后面的所有j结点比较,若符合条件则交换i、j结点位置。②然后后移i结点,执行步骤①直到i结点是倒数第二蛄点为止。
转载请注明原文地址:https://kaotiyun.com/show/sfOZ777K
本试题收录于:
三级网络技术题库NCRE全国计算机三级分类
0
三级网络技术
NCRE全国计算机三级
相关试题推荐
如下图所示,网络站点A发送数据包给B,在数据包经过路由器转发的过程中,封装在数据包1中的目地IP地址和目的MAC地址是()。
将Catalyst6500交换机的系统时间设定为“2014年3月26日,星期五,9点19分25秒”,正确配置是()。
如图所示是Windows2003系统DNS服务器中增加的1条资源记录,下列关于该资源记录的描述中,正确的是()。I创建的资源记录为邮件交换器记录II创建该记录时,在反向查找区域中创建相应的指针记录III该记录
下列方式中,利用主机应用系统漏洞进行攻击的是()。
下图是校园网某台主机在命令行模式执行某个命令时用sniffer捕获的数据包。请根据图中信息回答下列问题。(1)从该主机发送给mail.tj.edu.cn的数据包经过的第一个路由器的IP地址是【16】。(2)图中的①~③删除了部分显示信息,其中
CiscoPIX525防火墙可以进行操作系统映像更新的访问模式是()。
CiscoPIX525防火墙能够进行口令恢复操作的模式是()。
CiscoPIX525防火墙可以进行操作系统映像更新的访问模式是()。
随机试题
主动脉弓发出的动脉有()
根据《招标投标法》规定,下列关于招标文件编制工作的表述中不正确的是()。
目前,我国增值税的基本税率为()。
表面粗糙度与机器零件的()无关。
根据税收征收管理法律制度的规定,使用发票,不得有()行为。
Joyinlivingcomesfromhavingfineemotions,trustingthem,givingthemthe【E1】f______ofabirdintheopen.Joyinlivingcan
有两列正态变量x,y,其中Sx=4,Sy=2,Sx—y=3,求此两列变量的积差相关系数()。
以下不是我国知名的高性能巨型计算机的是
He(jumped)(over)thefence,ran(across)thefield,and(disappearing)intothewoods.
A、ThelatestversionoftheBible.B、AbookwrittenbyColumbus.C、AmapoftheNewWorld.D、OneoftheearliestcopiesofShake
最新回复
(
0
)