首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
文件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
2013-03-05
47
问题
文件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],chi[11];
int i;
fp=fopen("IN.DAT","r");
for(i;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=(long)sell
.price*sell
.amount;
}
fclose(fp);
}
void WriteData()
{
FILE*fp;
int i;
fp=fopen("OUT.DAT","w");
for(i=0;i
{
printf("%s%s%4d%4d%lold\n",sell
.ID,sell
.name,sell
.price,sell
.amount,sell
.value);
fprintf(fp,"%s%s%4d%4d%10ld\n",sell
.ID,sell
.name,sell
.price,sell
.amount,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
sell[j].value||(sell[i].value==sell[i].value&&strcmp(sell[i].ID,sell[j].ID)<0)) { memcpy(&.temp,&sell[i],sizeof(temp)); //将以&sell[i]为起始地址大小为sizeof(temp)的内存中的内容复制到以&temp为起始地址的内存中*/ memcpy(&.sell[i],&sell[j],sizeof(temp)); memcpy(&.sell[j],&.temp,sizeof(temp)); } }
解析
本题主要考查结构数组排序的问题。所谓结构数组排序就是以结构某一元素为依据对结构数组进行排序。排序的思想是(以从小到大为例);将当前数据与其后的各个数据相比较,如果当前的数据比其后的数据大,则将两数据进行交换,从而使得前面的数据小于后面的数据,达到从小到大排序的目的。但是由于结构不像变量那样可以通过简单的赋值来交换变量(如果要赋值的话需要对结构里的所有元素进行赋值替换,比较麻烦),所以在进行两个相邻结构交换时,用到内存拷贝函数来对内存的内容整体进行操作。
转载请注明原文地址:https://kaotiyun.com/show/Al4Z777K
本试题收录于:
三级网络技术题库NCRE全国计算机三级分类
0
三级网络技术
NCRE全国计算机三级
相关试题推荐
在计算机网络ISO/OSI开放系统互联7层参考模型中,最高一层是【 】。
IP数据报具有“生存周期”域,当该域的值为多少时数据报将被丢弃?
Unix历尽沧桑而经久不衰,IBM公司是Unix举足轻重的成员。该公司的Unix产品是
常用的数据传输速率单位有Kbps、Mbps、Gbps与Tbps。1Mbps等于
电子政务的发展大致经历了面向数据处理、面向信息处理和面向______3个阶段。
性能管理包括______两大功能。
路由器运行在OSI参考模型的_______。
在IEEE802系统协议中描述逻辑链路控制子层(LLC)的功能、特性和协议的是_______。
Unix系统采用了【 】文件系统,具有良好的安全性、保密性和可维护性。
随机试题
套管可分为表层套管、()和油层套管
已知某方案投资为15万元,每年的净现金效益量都为7万元,投资有效期为3年,成本是10%,(附:贴现率10%对应的总现值系数2.487),则净现值等于()
下列哪一种情况下最易引起高血钾
安全保证计划是施工组织设计的重要组成部分,下列项目属于计划内容的是()。
商业银行在综合理财服务活动中,可以向特定目标客户销售理财计划,下列关于保证收益理财产品(计划)的说法,正确的有()。
请认真阅读下文,并按要求作答。一个小村庄的故事在一片河坡上,早先有过一个美丽的村庄。村子里住着几十户人家,家家都有一两把锋利的斧头,谁家想盖房,谁家想造犁,就拎起斧头到山坡上
莫诺认为,生物进化,本质上是由无法预测的纯粹偶然变化造成的,人类的出现也不过是“蒙特卡诺赌窟里中签得彩的号码”。其错误在于()
以下四种排序方法中,需要附加的内存空间最大的是______。
Whatisthebesttitleofthepassage?
A、Athome.B、Attheairport.C、Intheman’scar.D、Bythesideofataxi.A
最新回复
(
0
)