资源描述:
《2013计算机等考三级《数据库技术》上机模拟题.docx》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型10位)、单价dj(整型)、数量sl(整型)、金额je(长整型)几部分组成。其中:金额=单价*数量可计算得出。函数ReadDat()的功能是读取这100个销售记录并存入结构数组sell中。请编制函数SortDat(),其功能要求:按产品代码从大到小进行排列,若产品代码相同,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件OUT10.DAT中。 注意:部分源程序已给出。 请勿改动主函数main
2、()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。 试题程序: #include #include #include #include #include #defineMAX100 typedefstruct{ chardm[5];/*产品代码*/ charmc[11];/*产品名称*/ intdj;/*单价*/ intsl;/*数量*/ longje;/*金额*/ }PRO; PROsell[MAX]; voidReadDat(); voidWriteDat(); voidSortDat() { } v
3、oidmain() { memset(sell,0,sizeof(sell)); ReadDat(); SortDat(); WriteDat(); } voidReadDat() { FILE*fp; charstr[80],ch[11];(51,51,51);font-family:宋体;font-size:14px;line-height:25px;"> inti; fp=fopen("IN.DAT","r"); for(i=0;i<100;i++){ fgets(str,80,fp); memcpy(sell[i].dm,str,4)
4、; memcpy(sell[i].mc,str+4,10); memcpy(ch,str+14,4);ch[4]=0; sell[i].dj=atoi(ch); memcpy(ch,str+18,5);ch[5]=0; sell[i].sl=atoi(ch); sell[i].je=(long)sell[i].dj*sell[i].sl; } fclose(fp); } voidWriteDat() { FILE*fp; inti; fp=fopen("OUT10.DAT","w"); for(i=0;i<100;i++){ fprintf
5、(fp,"%s%sM]1d",sell[i].dm,sell[i].mc,sell[i].dj,sell[i].sl,sell[i].je); } fclose(fp); } -------------------------------------------------------------------------------- voidSortDat() {intI,j; PROxy; for(I=0;I<99;I++) for(j=I+1;j<100;j++) if(sell[I].dm {xy=sell[I]; sell[I]=se
6、ll[j]; sell[j]=xy;}b(51,51,51);font-family:宋体;font-size:14px;line-height:25px;"> elseif(sell[I].dm==sell[j].dm) if(sell[I].je {xy=sell[I]; sell[I]=sell[j]; sell[j]=xy;} }