首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
已知在文件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
61
问题
已知在文件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://www.kaotiyun.com/show/sfOZ777K
本试题收录于:
三级网络技术题库NCRE全国计算机三级分类
0
三级网络技术
NCRE全国计算机三级
相关试题推荐
在一台Cisco路由器上封禁ICMP协议,只允许215.192.40.16/28和202.204.28.2/24子网的ICMP数据包通过路由器,下列正确的access—list配置是()。
通过拨号远程配置Cisco路由器时,应使用的接口是()。
执行路由器的iproute命令必须进入的工作模式是()。
一台Cisco6500交换机的4/1~24端口用于连接单个PC机和服务器,若需加快PC机和服务器接入到网络中的速度,STP可选功能的正确配置是()。
下列关于网络接入技术和方法的描述中,错误的是()。
下列对IPv6地址FE23:0:0:050D:BC:0:0:03DA的简化表示中,错误的是()。
CiscoPIX525防火墙用来允许数据流从具有较低安全级接口流向较高安全级接口的配置命令是()。
通过伪造某台主机的IP地址窃取特权的攻击方式属于()。
请根据下图所示网络结构回答下列问题。如果需要监听路由器RE和RG设备之间的所有流量,可以在该链路中串入一种设备。请写出这种设备的名称。
下列对交换机功能的描述中,错误的是()。
随机试题
以下不属于原始审美活动的是()
无名合同是指()
具有止血、抗炎、抗菌、抗瘤等作用的是具有抗菌及扩张冠状动脉作用的是
下列哪项措施不利于增加人造冠的摩擦力
与国家控制网比较,工程控制网的特点是()。
选择和制定教学方法的指导思想是提倡__________,反对注入式。
诱导需求,医生在涉及自身经济利益的服务中,医生既是顾问,又是卫生服务的提供者,因此可以创造额外需求,即供方创造需求。根据上述定义,下列说法不正确的是:
可持续发展是一种新的社会发展观,它的基本含义是保证人类社会具有长远、持续的发展能力。1978年第四十二届联合国大会通过的《我们共同的未来》报告将之表述为:“既要满足当代人的需要,又不致损害子孙后代满足其需要之能力的发展。”这一表述被公认为是对可持续发展这一
在报表豹设计视图中,不能使用的是
Britain’sdependencyoncertainessentialserviceshasgreatlywidenedandbecomeakeyroleinthecountry’s______.Unionwor
最新回复
(
0
)