首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
已知在文件IN5.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量sl(整型)、金额je(长整型)五部分组成。其中:金额=单价×数量。函数ReadDat()的功能是读取这1
已知在文件IN5.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量sl(整型)、金额je(长整型)五部分组成。其中:金额=单价×数量。函数ReadDat()的功能是读取这1
admin
2010-09-05
44
问题
已知在文件IN5.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量sl(整型)、金额je(长整型)五部分组成。其中:金额=单价×数量。函数ReadDat()的功能是读取这100个销售记录并存入结构数组sell中。请编制函数SortDat(),其功能要求:按金额从大到小进行排列,若金额相等,则按产品代码从小到大进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件OUT5.DAT中。
注意:部分源程序已给出。请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。
【试题程序】
#include <stdio.h>
#include <memory.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()
{
}
void main()
{
memset(sell,O,sizeof(sell));
ReadDat();
SortDat();
WriteDat();
}
void ReadDat()
{
FILE *fp;
char str[80],ch[11];
int i;
fp=fopen("IN5.DAT","r");
for(i=0; i<100; i++)
{
fgets(str,80,fp);
memcpy(sell[11].dm,str,4);
memcpy(sell[11].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(void)
{
FILE *fp;
int i;
fp=fopen("OUT5.DAT","w");
for(i=0;i<100;i++)
fprintf(fp,"%s %s %4d %5d %101dkn",sell
.dm,sell
.mc,sell
.dj,sell
.sl, sell
.je);
fclose(fp);
}
选项
答案
void SortDat() { int i,j; PRO xy; for(i=O;i<MAX-1;i++) for(j=i+l;j<MAX;j++) { if(sell[i].je<sell[j].je) /*按金额从大到小进行排列*/ { xy=sell[i];sell[ii=sell[j];sell[j]=xy;} else if(sell[i].je==sell[j].je) /*若金额相同*/ if(strcmp(sell[i].dm,sell[j].dm)>0) /*则按代码从小到大进行排列*/ { xy=sell[i];sell[i]=sell[j];sell[j]=xy; } }
解析
此题按金额从大到小进行排列,若金额相等,则按产品代码从小到大进行排列,相应语句为:
if((sell
.je<sell[j].je)‖(sell
.je==sell[j].je)&&(strcmp(sell
.dm,sell[j].dm)>O))
转载请注明原文地址:https://kaotiyun.com/show/0uvZ777K
本试题收录于:
三级数据库技术题库NCRE全国计算机三级分类
0
三级数据库技术
NCRE全国计算机三级
相关试题推荐
一个关系模式为Y(X1,X2,X3,X4),假定该关系存在如下函数依赖:X1←→X2,X1→X3,X1→X4,则该关系属于【】。
OracleOLAP是Oracle数据库系统的______解决方案。
从学生选课信息表中“找出无成绩的元组”的SQL语句是______。在“查询选修课程号为4,且成绩在80分以上的所有学生的学号和姓名”的SQL语句中,将使用的表是______。
下列问题基于如下描述:现有关键码值分别为10、20、30、40的4个节点,按所有可能的插入顺序去构造二叉排序树。
数据库管理系统中,为了保证事务的正确执行,维护数据库的完整性,要求数据库系统维护以下事务特性:_____、一致性、隔离性和持久性。
对一个模式的分解要求分解后产生的模式与原模式等价,对其等价性进行评价的两个主要标准是______、______。
下列问题基于以下的叙述:关系模式R(B,C,M,T,A,G),根据语义有如下函数依赖集:F={B→C,(M,T)→B,(M,C)→T,(M,A)→T,(A,B)→C}。
PowerDesigner是SYBASE公司的产品,属于CASE工具,与PowerDesigner是SYBASE公司的产品还有【】、【】和【】。
可以将一个堆序列看成是一棵完全二叉树结点的层次序列,下面关键序列()就是一个堆。
在操作系统中,系统是通过______来感知进程的存在,通过对它的访问来获得描述进程情况及控制进程运行的全部信息。
随机试题
患者,男性,50岁,腰背疼痛半年伴不规则发热、尿频、尿痛半年。检验:Hb75g/L,尿蛋白(+++),白细胞10~15/HP,尿B-J蛋白(+)。血清蛋白电泳在β和γ区带之间有一M蛋白占40%。外周血浆细胞25%,浆细胞绝对值2.3×109/L。本病最可能
诊断膀胱破裂的方法有()。
患部红肿高大,根盘紧束,楸热疼痛者为患部漫肿无头,皮色不变,局部麻木,不热少痛者为
理发师坐在店门口剪纸,他身上有()因素引起的压力感。
学生操行评定的一般步骤是()。
(2012年)设区域D由曲线y=sinχ,χ=±,y=1围成,则(χy5-1)dχdy=【】
在考生文件夹下有数据库文件“samp1.accdb”和Excel文件“Stab.xlsx”,“samp1.accdb”中已建立表对象“student”和“grade”,请按以下要求,完成表的各种操作。将考生文件夹下的Excel文件“Stab.xlsx”
HowMenFacetheFatProblemItisapleasuretoseemenofacertainageworryingabouttheirweight.Listeningtothemis
Moreandmorestudentswanttostudyin"hot"major.【C1】______aresult,manystudentswantto【C2】______theirinterestsandstudy
Packaging(包装)isanimportantformofadvertising.Apackagecansomethingmotivatesomeonebuyaproduct.Forexample,asmall
最新回复
(
0
)