首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
文件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
2011-06-14
68
问题
文件IN.DAT中存有200个销售记录,每个记录均由产品代码ID(字符型4位)、产品名称name(字符型10位)、单价price(整型)、数量amount(整型)、金额value(长整型)几部分组成。其中;金额=单价×数量,函数ReadData()负责将IN.DAT中的数据读到结构数组sell[]中。请编制函数sortData(),将各个记录按产品代码从小到大进行排列,若产品代码相同,则按金额从小到大进行排列,并将排列后的结果存放NUsell[]中。函数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(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[-i].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%101d\u",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
.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
0 ||(strcmp(sell[i].ID,sell[j].ID)==0&&sell[i].value>sell[j].value)) { 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/XraZ777K
本试题收录于:
三级网络技术题库NCRE全国计算机三级分类
0
三级网络技术
NCRE全国计算机三级
相关试题推荐
ATM层类似于【 】层协议。
由于各个物理网络所能处理的最大报文长度可能不同,所以IP报文在传输和投递过程中有可能被【 】。
下列关于WindowsNT服务器的描述中,正确的是()。
在TCP/IP协议集中,TCP和【 】协议运行于传输层。
采用拨号上Internet一般需要有计算机、普通电话、通信软件和______。
假冒是大多数黑客采用的攻击方法,不属于它的属性的是()。
为了方便用户记忆,IP地址采用【 】标记法。
我国的信息安全标准分为自主保护、【 】、安全标记保护、结构化保护和访问验证保护5个等级。
随机试题
下列有关牙齿发育的叙述,不正确是:()
细胞凋亡的失调是许多疾病的发病机制之一。
舌苔黑而润滑多属
将多个护理诊断排列优先顺序时,其中次优问题是
患者,女,30岁,白带增多半年,妇科检查发现:阴道壁充血,宫颈光滑,白带呈稀薄泡沫状。该病常用的阴道冲洗液为()
甲公司于2014年9月与乙公司签订一项期限为8个月的培训服务,合同约定的培训费用为120万元。2014年12月31日根据合同规定乙公司向甲公司支付培训费50万元,甲公司实际发生的培训成本为20万元(均为职工薪酬),预计还将发生60万元。甲公司采用完工
《国民经济和社会发展第十二个五年发展规划纲要》指出,要坚持把()作为加快经济发展方式转变的根本出发点和落脚点。
循环队列的存储空间为Q(1:100),初始状态为front=rear=100。经过一系列正常的入队与退队操作后,front=rear=99,则循环队列中的元素个数为()。
EattoLiveAmeagerdietmaygiveyouhealthandlonglife,butit’snotmuchfun—anditmightnotevenbenecessary.Wema
In1959theaverageAmericanfamilypaid$989forayear’ssupplyoffood.In1972thefamilypaid$1,311.Thatwasaprice
最新回复
(
0
)