首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
文件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
2012-07-20
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],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);
memepy(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[,i].amount;
}
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
.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)) { memcpy(&temp,&sell[i],sizeof(temp)); /*将以&sell[i]为起始地址、大小为sizeof(temp) 的内存中的内容复制到以&.temp为起始地址的内存中*/ memcpy(&sell[i],&.sell[j],sizeof(temp)); memcpy(&.sell[j],&temp,sizeof(temp)); } }
解析
本题考查的主要是结构数组排序的问题。所谓结构数组排序就是以结构中某一元素为依据对结构数组进行排序。本题排序的思想是;将当前数据与其后的各个数据相比较,如果当前数据比其后的数据小,则将两数据进行交换,从而使得前面的数据大于后面的数据,达到从大到小排序的目的。但是由于结构不像变量那样可以通过简单的赋值来交换变量(如果要赋值的话需要对结构里的所有元素进行赋值替换,比较麻烦),所以在进行两个相邻结构交换时,要用到内存拷贝函数memcpy()来对内存的内容整体进行操作。
转载请注明原文地址:https://jikaoti.com/ti/g8R7FFFM
本试题收录于:
三级网络技术题库NCRE全国计算机三级分类
0
三级网络技术
NCRE全国计算机三级
相关试题推荐
在TCP/IP参考模型中,互连层的主要功能不包括下述______。
帧中继(FrameRelay)是在X.25分组交换的基础上,简化了差错控制、流量控制和【 】功能,而形成的一种新的交换技术。
就资源管理和用户接口而言,操作系统的主要功能包括:处理器管理、存储管理、设备管理和______。
文件服务器具有分时系统文件管理的全部功能,能够为用户提供完善的数据、文件和______。
应用层DNS协议主要用于实现的网络服务功能是
NetWare文件系统所有的目录与文件都建立在【 】硬盘上。
对称型加密对数据进行加密或解密所使用的密钥个数是
下列不是网络层的功能的是
NetWare的三级容错机制,说法正确的是Ⅰ.SFTⅠ针对硬盘表面磁介质可能故障而设计Ⅱ.SETⅡ针对硬盘控制器和硬盘电路故障而设计Ⅲ.SFTⅢ提供了操作系统备份功能Ⅳ.SFTⅠ采用双重目录与文件分配表,磁
随机试题
用于显示小胶质细胞的染色方法是
光镜的最大分辨率约()。
甲公司2019年11月10日与乙公司签订一项生产线维修合同。合同规定,该维修总价款为100万元,合同期为6个月。合同签订日预收价款50万元,至12月31日,已实际发生维修费用35万元,预计还将发生维修费用15万元。甲公司按实际发生的成本占总成本的比例确定劳
根据生命周期理论,家庭生命周期各阶段中可承受投资风险最高的是()。
以下不属于西藏特产的有()。
足球比赛开始前,裁判员应召集双方队长,用投币的方式决定_______和_______。
当人确信自己有能力进行某一活动时,就会产生高度的(),并去进行这一活动。
从1997.09.30到2000.03.10间,接收的申请人总数为:1997.09.30-1998.07.01接收的申请人数占这几年接收总数的百分比是:
安德森的产生式迁移理论是()的现代翻版。
对(甲)文中“不必太滞”理解正确的一项是:从(丙)文我们得知陶渊明其号______的来历,而自传中所表现的情趣与其诗作______、______颇为一致。
最新回复
(
0
)