- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
上机试题总结 作者 :GAME.JACK 转自中国IT认证实验室IT社区
100个产品销售记录排序(此类共10题) code:/*已知在文件IN.DAT中存有100个产品销售记录, 每个产品销售记录由产品代码dm(字符型4位), 产品名称mc(字符型10位), 单价dj(整型), 数量sl(整型), 金额je(长整型)五部分组成。 其中:金额=单价*数量计算得出。函数ReadDat( )读取这100个销售记录并存入结构数组sell中。请编制函数SortDat( ), 其功能要求:按金额从小到大进行排列, 若金额相等, 则按产品代码从小到大进行排列, 最终排列结果仍存入结构数组sell中。最后main( )函数调用函数WriteDat()把结果输出到文件OUT1.DAT中。注意: 部分源程序存放在PROG1.C中。请勿改动主函数main( )、读数据函数ReadDat()和输出数据函数WriteDat()的内容。*/#include stdio.h#include mem.h#include string.h#include conio.h#include stdlib.h
#define MAX 100typedef struct {char dm[5] ; /* 产品代码 */char mc[11] ; /* 产品名称 */int dj ; /* 单价 */int sl ; /* 数量 */long je ; /* 金额 */} PRO ;PRO sell[MAX] ;void ReadDat() ;void WriteDat() ;
void SortDat(){/**/int i,j,k;PRO tt;for(i=0; i MAX-1; i++){ k=i;for(j=i+1; j MAX; j++)if((sell[k].jesell[j].je)||(sell[k].je==sell[j].je)(strcmp(sell[k].dm, sell[j].dm)0))k=j;if(k!=i){ tt=sell[k]; sell[k]=sell[i]; sell[i]=tt;}}/**/}
void main(){memset(sell, 0, sizeof(sell)) ;ReadDat() ;SortDat() ;WriteDat() ;}
void ReadDat(){FILE *fp ;char str[80], ch[11] ;int i ;
fp = fopen(IN.DAT, r) ;for(i = 0 ; i 100 ; i++) {fgets(str, 80, fp) ;memcpy(sell[i].dm, str, 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) ;}
void WriteDat(){FILE *fp ;int i ;
fp = fopen(OUT1.DAT, w) ;for(i = 0 ; i 100 ; i++) {fprintf(fp, %s %s %4d %5d %10ld\n, sell[i].dm, sell[i].mc, sell[i].dj, sell[i].sl, sell[i].je) ;}fclose(fp) ;}
100个产品销售记录排序其余9题说明 1) in.dat 内容完全相同。 2) 程序也基本雷同,仅排序的要求不一样。 3) 考生应熟悉 strcmp() 函数,否则有的题相当不好处理。 之二 排序要求: 按金额从小到大进行排列, 若金额相等, 则按产品代码从大到小 进行排列 相应语句: if(sell[k].jesell[j].je|| (sell[k].je==sell[j].je) (strcmp(sell[k].dm, sell[j].dm) 0))
之三 排序要求: 按金额从大到小进行排列, 若金额相等, 则按产品代码从小到大 进行排列 相应语句: if((sell[k].je sell[j].je)||(sell[k].je==sell[j].je)(strcmp
您可能关注的文档
最近下载
- 2024年第十六届全国大学生数学竞赛初赛试卷及参考答案(非数学B类).pdf VIP
- 自考本科《小学综合性学习与跨学科教学》2025年4月模拟题附答案.docx VIP
- 高校教师培训教学设计模板.docx VIP
- 《野外辨别方向》课件.ppt VIP
- 2024年第十六届全国大学生数学竞赛初赛试卷及参考答案(非数学A类).pdf VIP
- 医务人员职业防护.ppt VIP
- 第42届全国中学生物理竞赛复赛试题.docx VIP
- 万科示范区验收移交指引.docx VIP
- 唐代僧人的法律规范-政大机构典藏.PDF
- 2025-2026学年高二地理上学期第一次月考卷5【测试范围:选择性必修一,第1~2章第1节】(原卷及解析).docx VIP
文档评论(0)