首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc (字符型10位)、单价dj(整型)、数量s1(整型)、金额je(长整型)五部分组成。其中:金额=单价*数量计算得出。函数ReadDat()是读取这
已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc (字符型10位)、单价dj(整型)、数量s1(整型)、金额je(长整型)五部分组成。其中:金额=单价*数量计算得出。函数ReadDat()是读取这
admin
2010-09-05
34
问题
已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc (字符型10位)、单价dj(整型)、数量s1(整型)、金额je(长整型)五部分组成。其中:金额=单价*数量计算得出。函数ReadDat()是读取这100个销售记录并存入结构数组sell中。请编制函数SortDat(),其功能要求:按产品代码从大到小进行排列,若产品代码相同,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WritcDat()把结果输出到文件OUT8.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[ll]; /*产品名称*/
iht dj; /*单价*/
int sl; /*数量*/
long je; /*金额*/
}PRO;
PRO sell[MAX];
void ReadDat();
void WriteDat();
void SortDat ()
{
void main ()
{
memset(sell,0,sizeof(sell));
ReadDat();
SortDat();
WriteDat();
}
void ReadDat()
{
FILE *fp;
char str[80],ch[ll];
int i;
fp=fopen("IN.DAT","r");
for(i=0;i<100;i++){
fgets(str, 80,fp);
memcpy(setl
.dm, str, 4);
memcpy(sell
.mc, str+4,10);
memcpy(ch, str+14,4);ch[4]=0;
sell
.dj=atoi(ch);
memcpy(ch, str+lS,5);ch[5]=0;
sell
.sl=atoi(ch);
sell
.je=(long)sell
.dj*sell
.s1;
}
fclose(fp);
}
void WriteDat(void)
{
FILE *fp;
int i;
fp=fopen("OUT8.DAT","w");
for(i=0;i<100;i++){
fprintf(fp,"%s%s%4d %5d %10Ld\n", sell
.dm, sell
.mc,sell
.dj,
sell
.sl,sell
.je);
}
fclose(fp);
}
选项
答案
void SortDat() { int i,j; PRO swap; for(i=0;i<MAX-1;i++) for(j=i+1;j<MAX;j++) /*根据题目要求进行结构体比较*/ if((strcmp(sell[i].dm,sell[j],dm)<0 || strcmp(sell[i].dm, sell[j].dm)==0)&&sell[i].je<sell[j].je) { /*结构体赋值,sell[i]中始终保存第i轮扫描的当前最小记录*/ swap=sell [i]; sell [i]=sell [j]; sell [j]=swap; } }
解析
类型:结构体排序。
关键点:结构体比较和排序。
与整数排序类似,只是进行结构体计算、比较和赋值。
转载请注明原文地址:https://kaotiyun.com/show/auvZ777K
本试题收录于:
三级数据库技术题库NCRE全国计算机三级分类
0
三级数据库技术
NCRE全国计算机三级
相关试题推荐
设关系R,S和T分别如下图所示。则有
下列哪一个术语与数据的存储结构有关?
数据模型用来描述数据的静态特征、动态特征和完整性约束,对定义在数据上的操作进行描述是描述数据的_____。
一个关系模式为Y(X1,X2,X3,X4),假定该关系存在如下函数依赖;X1→X2,X1→X3,X3→X4,则该关系属于【】,因为它存在着【】。
存取方法设计是为存储在物理设备上的数据提供访问路径,一般采用索引方式,它是属于()阶段的设计内容。
操作系统的安全措施有【】、【】和【】。
在数据库的三级模式体系结构中,存在两次映像,一次是从外模式到模式的映像,一次是______到______的映像。
下列问题基于以下的叙述:关系模式R(B,C,M,T,A,G),根据语义有如下函数依赖集:F={B→C,(M,T)→B,(M,C)→T,(M,A)→T,(A,B)→C}。
设有两个散列函数H1(K)=Kmod13和H2(K)=Kmod11+1,散列表为了[0...12],用双重散列法(又称二次散列法)解决冲突。函数H1用来计算散列地址,当发生冲突时,H2作为计算下一个探测地址的地址增量。假定某一时刻散列表T的状态为:
通过视图进行查询,首先要进行【】。
随机试题
简述压力的性质。
A.依地酸钙钠B.亚甲蓝C.纳洛酮D.氟马西尼亚硝酸盐中毒的解毒药是
分析计数资料时,最常用的显著性检验方法是
高血压伴有心动过速、汗出首先应考虑
2017年1月1日,甲公司发行2年期的可转换公司债券,每年1月1日付息、到期一次还本,面值总额为1000万元,实际收款1100万元,票面利率为4%,假定实际利率为5%。可转换公司债券中包含的负债成分的公允价值为985万元,该债券在发行1年后可以转换为甲公司
描述样本中心位置的统计量有()。
亲戚想让你帮他合理、合法地少交税款,你怎么办?
x=-10,x=0(三重)
Iamlookingforwardto______fromyou.
Driver’sLicenseTestTipsA)Thisarticlewillprovideyouwithsomesimpletipsforpassingyourdriver’slicensetest.Adequat
最新回复
(
0
)