首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
已知在文件IN6.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量s1(整型)、金额je(长整型)几部分组成。其中:金额=单价×数量。函数ReadDat()的功能是读取这1
已知在文件IN6.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量s1(整型)、金额je(长整型)几部分组成。其中:金额=单价×数量。函数ReadDat()的功能是读取这1
admin
2009-02-19
71
问题
已知在文件IN6.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量s1(整型)、金额je(长整型)几部分组成。其中:金额=单价×数量。函数ReadDat()的功能是读取这100个销售记录并存入结构数组sell中。请编制函数SortDat(),其功能要求:按产品名称从小到大进行排列,若产品名称相同,则按金额从小到大进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件OUT6.DAT中。
注意:部分源程序已给出。
清勿改动主函数main()、读函数ReadDat()和写函数WriteDat()的内容。
试题程序:
#include <stdio.h>
#include <mem.h>
#include <string.h>
#include <conio.h>
#include <stdlib.h>
#define MAX 100
typedef struct
{
char dm[5]; /*产品代码 */
char mc[11]; /* 产品名称 */
int dj; /* 单价 */
int sl; /* 数量 */
long je; /* 金额 */
} PRO;
PRO sell [MAX];
void ReadDat();
void WriteDat();
void SortDat()
{
main ( )
{
memset (sell, 0, sizeof(sell));
ReadDat ( );
SortDat ();
WriteDat ( )
}
void ReadDat(
{
FILE *fp;
char str[80], ch[11];
int i;
fp = fopen("IN6.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;
sell
.dj = atoi{ch);
memcpy(ch, str +18, 5); ch[5] = 0;
sell
.sl = atoi(ch);
sell
.je = (long)sell
.dj * sell
.sl;
}
fclose (fp)
}
void WriteDat
{
FILE *fp;
int i;
fp = fepen("OUT6.DAT", "w");
for(i = 0; i < 100; i++)
{
fprintf (fp, "%s %s %4d %5d %101d\n", sell
.dm, sell
.mc,
sell
.dj,sell
.sl, sell
.je);
}
fclose(fp);
}
选项
答案
void SortDat() { int i,j; PRO xy; for (i=0; i<99; i++) for (j =i+1; j<100; j ++) if (strcmp (sell [i].mc, sell [j].mc)>0) /*按产品名称从小到大进行排列* / {xy=sell[i] ;sell [i] =sell [j] ;sell[j]=xy;} else if (strcmp (sell [i].mc, sell [j] .mc) ==0) /*若产品名称相同*/ if (sell [i]. je>sell [j].je) /*则按金额从小到大进行排列车员*/ {xy=sell[i] ;sell[i]=sell[j] ;sell[j]=xy;
解析
本题是有关结构体数组的排序问题,可以用选择法来实现。用第一个元素的产品名称依次和它后面的元素的产品名称进行比较,如果发现当前元素的产品名称比后面的某个元素的产品名称对应字符的ASCII码大(这里用到了字符串比较函数strcmp()),则交换这两个元素的位置,继续和后面的其他元素进行比较,最终在第一个元素中存放的是产品名称最小的元素。以此类推,就实现了从小到大排序的功能。注意:这里要进行交换的是两个结构体变量,而不是它们的某一个域,因此,要借助第三个结构体变量来充当中间容器。若产品名称相同,则要按照金额从小到大进行排序。
转载请注明原文地址:https://kaotiyun.com/show/QoSZ777K
本试题收录于:
三级数据库技术题库NCRE全国计算机三级分类
0
三级数据库技术
NCRE全国计算机三级
相关试题推荐
在下列有关386处理器工作模式的叙述中,错误的是( )。
下述通信标准中,不采用差分方式进行信号传输的是()。
关于U—Boot,以下说法错误的是()。
如下几种Bootloader中,用于Linux操作系统引导程序加载时所支持不同体系结构处理器种类最多的是()。
μC/OS-II能够提供周期性时钟信号(即所谓的时钟节拍),用于实现任务的正确延时和超时确认。节拍率应在什么范围内?
将R1中的8位二进制数存储到由R2+1指示的单元,并自动更新地址的ARM指令是()。
随着无线通信技术的发展,用户不受时间地点约束,随时随地访问互联网已经成为现实。目前采用无线方式接入互联网的技术主要有3类,它们是【45】接入、GPRS移动电话网接入和3G移动电话网接入,第1类接入方式必须在安装有【46】的区域中才能接入。
在μC/OS—II中,OSInit()函数先建立最初的任务就绪表,然后建立4个空白的数据链表。这4个空白的数据链表是()。
数据库管理系统、图形用户界面、互联网浏览器、媒体播放器等软件,如果运行在嵌入式系统上,往往具有内部结构精简,__________【69】轻量化,占用存储资源__________【70】的特点。
m阶B树的根结点若不是叶结点,那么它至多有m棵子树,至少有()棵子树。
随机试题
隐睾对人体构成的危险是_______。
男,37岁,右腰部钝器击伤1小时,面色苍白,脉搏细弱110次/分,血压9.3/6.7kPa(70/50mmHg)。右肾区.较左侧饱满,触痛,腹部平软,无压痛,反跳痛及肌紧张。移动性浊音(-)。肠鸣音正常,导尿引流出黄色澄清尿液约200ml。经快速静脉输
在牧歌太阳能公司诉童某的买卖合同诉讼中,童某的儿子提出童某是间歇精神病患者,向法院提交了精神病院的诊断书与童某病历,申请宣告童某为限制民事行为能力人,本案处理方案中错误的有:()
【2011专业知识真题上午卷】高压并联电容器组采用双星形接线时,双星形电容器组的中性点连接线的长期允许电流不应小于电容器组额定电流的百分数为下列哪项数值?()
德育过程中的基础是()。
根据下面的材料,回答下列题。2014年1—5月,我国软件和信息技术服务业实现软件业务收入约13254亿元,同比增长20.9%,比去年同期回落3.3个百分点。其中,软件产品完成收入4141亿元,信息系统集成服务完成收入2649.3亿元,信息技术咨询
描述安全性级别划分的指标是( )、( )、( )和( )。
目前常用和流行的浏览器软件有两种:一种是Microsoft公司推出的InternetExplorer(IE),另一种是Netscape公司推出的
面向对象方法中,继承是指()。
多继承的构造顺序可分为如下四步:①所有非虚基类的构造函数按照它们被继承的顺序构造②所有虚基类的构造函数按照它们被继承的顺序构造③所有子对象的构造函数按照它们声明的顺序构造④派生类自己的构造函数体这四个步骤
最新回复
(
0
)