首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
文件IN.DAT中存有200个销售记录。每个记录均由产品代码ID(字符型4位)、产品名称name(字符型10位)、单价price(整型)、数量amount(整型)、金额value(长整型)几部分组成。其中:金额=单价×数量.函数ReadData()负责将I
文件IN.DAT中存有200个销售记录。每个记录均由产品代码ID(字符型4位)、产品名称name(字符型10位)、单价price(整型)、数量amount(整型)、金额value(长整型)几部分组成。其中:金额=单价×数量.函数ReadData()负责将I
admin
2021-06-16
31
问题
文件IN.DAT中存有200个销售记录。每个记录均由产品代码ID(字符型4位)、产品名称name(字符型10位)、单价price(整型)、数量amount(整型)、金额value(长整型)几部分组成。其中:金额=单价×数量.函数ReadData()负责将IN.DAT中的数据读到结构数组sell[-]中。请编制函数sortData(),将各个记录按金额从小到大进行排列,若金额相同,则按产品代码从大到小进行排列,并将排列后的结果存放到sell[]中。函数WriteData()负责将sell[]中的数据输出到文件OUT.DAT中。
注意:部分源程序已给出。
请勿改动主函数main()、读函数ReadData()和写函数WriteData()的内容。
试题程序:
#include
#include
#include
#include
#define MAX 200
typedef struct
{
char ID[5]; //产品代码
char name[11];//产品名称
int price; //单价
int amount; //数量
long value; //金额
}
PRODUCT;
PRODUCT sell[MAX];
void ReadData();
void WriteData();
void sortData()
{
}
void ReadData()
{
FILE*fp;
char str[80],ch[11];
int i;
fp=fopen(“IN.DAT”,“r”);
for(j=0;i
{
fgets(str.80,fp);
memcpy(sell
.ID,str,4);
memcpy(sell
.name,str+4,10);
memcpy(ch.str+14.4);ch[4]=’\0’;
sell
.price=atoi(ch);
memcpy(ch,str+18,4); ch[4]=’\0’;
sell
.amount=atoi(ch);
sell
.value=(10ng)sell
,price * sellEi3.a
mount;
}
fclose(fp);
}
void WriteData()
{
FILE*fp;
int i;
fp=fopen(“OUT.DAT”,“W”);
for(i=0;i
{
printf(“%s%s%4d%4d%101d\n”,sell
.
ID,sell
.name,sell
.price,sell
.amount,
sell
.value);
fprintf(fp,“%S%S%4d%4d%101d\n”,sell
.ID,sell
.name,sell
.price,sell
.a
mount,sell
.value);
}
fclose(fp);
}
void main()
{
memset(sell.0,sizeof(sell));
ReadData();
sortData();
WriteData();
}
选项
答案
void sortData() { PRODUCT temp ; int i,j; memset(temp,0;sizeof(temp)); for(i=0;i
sen[j].value||(sell[i].value= =sell[j].value&&stremp(sell[i].ID,sell[j].ID)< 0)) { memepy(&temp,&sell[i].sizeof(temp)); //将以&selll,i]为起始地址、大小为sizeof(temp) 的内存中的内容复制到以&temp为起始地址 的内存中*/ memcpy(&sell[i],&sell[j],sizeof(temp)); memepy(&sell[j[,&temp,sizeof(temp)); } }
解析
本题主要考查结构数组排序的问题。
所谓结构数组排序就是以结构某一元素为依据对结构数组进行排序。排序的思想是(以从小到大为例):将当前数据与其后的各个数据相比较,如果当前的数据比其后的数据大,则将两数据进行交换,从而使得前面的数据小于后面的数据,达到从小到大排序的目的。但是由于结构不像变量那样可以通过简单的赋值来交换变量(如果要赋值的话需要对结构里的所有元素进行赋值替换。比较麻烦),所以在进行两个相邻结构交换时。用到内存拷贝函数来对内存的内容整体进行操作。
转载请注明原文地址:https://kaotiyun.com/show/NfOZ777K
本试题收录于:
三级网络技术题库NCRE全国计算机三级分类
0
三级网络技术
NCRE全国计算机三级
相关试题推荐
在下面的攻击手段中,基于网络的入侵防护系统无法阻断的是()。
下列关于Serv—UFTP服务器安装、配置的描述中,错误的是()。
以下关于OSPF协议的描述中,错误的是()。
不同AS之间使用的路由协议是()。
某公司网络DHCP服务器地址为192.168.0.2,可分配IP地址为192.168.0.6~192.168.0.254,缺省网关的地址为192.168.0.1,DNS服务器地址为192.168.0.2。网络中某客户机从服务器获取IP地址后,在客户机上执行
将一台Catelyst3548的系统时间设置为2014年6月14日星期六的11点20分10秒,下列配置命令正确的是()。
CiscoCatalyst6500交换机采用telnet远程管理方式进行配置,其设备管理地址是194.56.9.178/27,缺省路由是194.56.9.161,下列对交换机预先进行的配置,正确的是()。
下列关于综合布线的描述中,错误的是()。
下列关于集线器的描述中,正确的是
实际吞吐量为28—31Mbps,最大容量为432Mbps的IEEE802.11标准是()。
随机试题
考生文件夹下存在一个数据库文件“samp3.accdb”,里面已经设计好表对象“tEmployee”和宏对象“m1”。同时还设计出以“tEmployee”为数据源的窗体对象“fEmployee”。试在此基础上按照以下要求补充窗体设计:(1)在窗体
博美犬,3岁,被萨摩犬咬伤。次日发现右腹壁出现局限性肿胀,触摸患处皮肤温热、柔软,按压肿物可变小。
当前我国对矿山企业行使监督管理的职责部门是县级以上各级人民政府的()部门。
释迦三圣是指()。
二、根据以下资料,回答下列题。 2008年上半年贵州农民人均生活现金消费支出为700.92元,考虑价格因素增长5.5%:城镇居民人均生活消费支出为4086.28元,比上年同期名义增长8.46%。支出增加的同时其结构也发生了一些变化。2008年上
(2015河南)莫高窟是古代先民聪明智慧的结晶。莫高窟选址在戈壁荒漠的绿洲之中,体现了佛教与世俗隔离、与自然融合的思想。洞窟依山面水,河水滋润着莫高窟周围的绿树,形成了独特的清幽风光。莫高窟呈蜂窝状排列的洞窟最高处不超过40米。冬季,从西边刮来的风沙经窟顶
南北时代
快速排序算法中,如何选取一个界值(又称为轴元素),影响着快速排序的效率,而且界值也并不一定是被排序序列中的一个元素。例如,可以用被排序序列中所有元素的平均值作为界值。编写算法实现以平均值为界值的快速排序方法。
张经理在公司大会上宣布:“此次提出的方案得到一致赞同,全体通过。”会后,小陈对此事进行了调查,发现张经理所言不是事实。如果小陈的发现为真,下面哪项也必然是事实?
There’sbeenalotoftalk【C1】______aboutwhoshouldgotocollegeandwhoshouldnot.Andthe【C2】______thathaveguidedthista
最新回复
(
0
)