| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 515 人关注过本帖
标题:100题12题
只看楼主 加入收藏
redalert
Rank: 1
等 级:新手上路
帖 子:103
专家分:0
注 册:2005-2-4
收藏
 问题点数:0 回复次数:0 
100题12题

12:已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位),产品名称mc(字符型10位),单价dj(整型),数量sl(整型),金额je(长整型)四部分组成。其中:金额=单价*数量计算得出。函数ReadDat()是读取这100个销售记录并存入结构数组sell中。请编制函数SortDat(),其功能要求:按产品名称从小到大进行排列, 若产品名称相同, 则按金额从小到大进行排列.最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件OUT5.DAT中。
注意: 部分源程序存放在PROG1.C中。
请勿改动主函数main( )、读数据函数ReadDat()和输出数据函数WriteDat()的内容。
----------------------------------
void SortDat()
{
int I,j;
PRO xy; /*PRO 为已定义的结构体*/
for(I=0;I<99;I++)
for(j=I+1;j<100;j++)
if(strcmp(sell[I].dm,sell[j].dm)<0) /*如果I的代码值小于j的代码值 我个人感觉这里也不符合题意啊!题中不是要求从小到大排列么?*/
{
xy=sell[I];
sell[I]=sell[j];
sell[j]=xy;
}
else if(strcmp(sell[I].dm,sell[j].dm)==0) /*如果相等*/
if(sell[I].je<sell[j].je) /*又如果I的金额小于j的金额*/
{
xy=sell[I];
sell[I]=sell[j];
sell[j]=xy;
}
}

搜索更多相关主题的帖子: color 产品 记录 
2006-03-16 15:02
快速回复:100题12题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.024277 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved