药店的药品销售统计系统排序应用.doc

上传人:叶*** 文档编号:35549086 上传时间:2022-08-22 格式:DOC 页数:21 大小:75.50KB
返回 下载 相关 举报
药店的药品销售统计系统排序应用.doc_第1页
第1页 / 共21页
药店的药品销售统计系统排序应用.doc_第2页
第2页 / 共21页
点击查看更多>>
资源描述

《药店的药品销售统计系统排序应用.doc》由会员分享,可在线阅读,更多相关《药店的药品销售统计系统排序应用.doc(21页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、实验五 药店的药品销售统计系统排序应用一、实验目的1. 帮助读者复习C+语言程序设计中的知识。2. 对数据进展排序时,可采用多种排序方法,如直接插入排序、冒泡排序、快速排序,直接选择排序等方法的实现。需求分析 设计一系统,实现医药公司定期对销售各药品的记录进展统计,可按药品的编号、单价、销售量或销售额做出排名。二、实验内容和要求问题要求设计一系统,实现医药公司定期对销售各药品的记录进展统计,可按药品的编号、单价、销售量或销售额做出排名。问题分析在本设计中,首先从数据文件中读出各药品的信息记录,存储在顺序表中。各药品的信息包括:药品编号、药名、药品单价、销出数量、销售额。药品编号共4位,采用字母

2、和数字混合编号,如:125,前一位为大写字母,后三位为12 数字,按药品编号进展排序时,可采用基数排序法。对各药品的单价、销售量或销售额进展排序时,可采用多种排序方法,如直接插入排序、冒泡排序、快速排序,直接选择排序等方法。在本设计中,对单价的排序采用冒泡排序法,对销售量的排序采用快速排序法,对销售额的排序采用堆排序法。三、算法设计首先从txt文件中读取数据信息并保存,本次试验采用了5中排序方法。其中编号排序是按照基数排序,采用多关键字进展排序。基数排序是借助“分配和“收集两种操作对单逻辑关键字进展排序的一种内排序方法。对单价的排序采用了直接插入排序和冒泡排序,直接插入排序就是首先将第一个元素

3、看成是一个有序的,然后第二个元素和第一个比拟,假设大于第一个那么放在其后面否那么放前面,依次直至最后一个。冒泡排序就是采用两个循环,即将第一个元素和第二个比拟假设第一个大于第二个那么交换,否那么不变,然后第二个和第三个比拟,同上。第一趟可将最大的一个放在最后,依次可得排序。销售量是快速排序,快速排序就是首先设置一个关键字,然后让最后一个和其比拟,直至找到一个比关键字小的,然后和其交换,接下来让第一个和其比拟,直至找到一个比其大的,然后交换,在找到的位置分别做标记,依次执行即可。销售额使用的是堆排序,堆排序首先要建立一个完全二叉树的堆,其标准符合为父节点始终比子节点大。然后依次输出顶结点,然后在

4、建立一个符合标准的堆重复操作即可。四、调试分析及数据测试输入药品五、测试结果测试结果符合程序写作要求#include#include#include#define maxsize 100 /该医药公司药品最大种类typedef struct node /药品信息的存储构造类型定义char num10; /药品编号char name30;float price; /单价int count; /销售量float sale; /销售额DataType;typedef struct /存储药品信息的顺序表的定义DataType rmaxsize;int length;int type;SqList;v

5、oid number(SqList *L) /按药品编号排序int i,j;char num110,name130;float price1,sale1;int count1;for(i=0;itype;i+)for(j=i+1;jtype;j+)if(strcmp(L-rj.num,L-ri.num)0) strcpy(num1,L-rj.num);strcpy(L-rj.num,L-ri.num);strcpy(L-ri.num,num1);strcpy(name1,L-rj.name);strcpy(L-rj.name,L-ri.name);strcpy(L-ri.name,name1)

6、;price1=L-rj.price;L-rj.price=L-ri.price;L-ri.price=price1;count1=L-rj.count;L-rj.count=L-ri.count;L-ri.count=count1;sale1=L-rj.sale;L-rj.sale=L-ri.sale;L-ri.sale=sale1;printf(t按药品编号排序后:n);printf(t药品编号 药品名称 药品单价 药品销售量 药品销售额n);for(i=0;itype;i+)printf(t %st %st %ft %dt %fn,L-ri.num,L-ri.name,L-ri.pric

7、e,L-ri.count,L-ri.sale);void nam(SqList *L) /按药品名称排序int i,j;char num110,name130;float price1,sale1;int count1;for(i=0;itype;i+)for(j=i+1;jtype;j+)if(strcmp(L-rj.name,L-ri.name)0) strcpy(num1,L-rj.num);strcpy(L-rj.num,L-ri.num);strcpy(L-ri.num,num1);strcpy(name1,L-rj.name);strcpy(L-rj.name,L-ri.name)

8、;strcpy(L-ri.name,name1);price1=L-rj.price;L-rj.price=L-ri.price;L-ri.price=price1;count1=L-rj.count;L-rj.count=L-ri.count;L-ri.count=count1;sale1=L-rj.sale;L-rj.sale=L-ri.sale;L-ri.sale=sale1;printf(t按药品编号排序后:n);printf(t药品编号 药品名称 药品单价 药品销售量 药品销售额n);for(i=0;itype;i+)printf(t %st %st %ft %dt %fn,L-ri

9、.num,L-ri.name,L-ri.price,L-ri.count,L-ri.sale);void pric(SqList *L)int i=0,j;char num110,name130;float price1,sale1;int count1;for(i=0;itype;i+)for(j=i+1;jtype;j+)if(L-rj.priceL-ri.price)strcpy(num1,L-rj.num);strcpy(L-rj.num,L-ri.num);strcpy(L-ri.num,num1);strcpy(name1,L-rj.name);strcpy(L-rj.name,L

10、-ri.name);strcpy(L-ri.name,name1);price1=L-rj.price;L-rj.price=L-ri.price;L-ri.price=price1;count1=L-rj.count;L-rj.count=L-ri.count;L-ri.count=count1;sale1=L-rj.sale;L-rj.sale=L-ri.sale;L-ri.sale=sale1;printf(t按药品编号排序后:n);printf(t药品编号 药品名称 药品单价 药品销售量 药品销售额n);for(i=0;itype;i+)printf(t %st %st %ft %dt

11、 %fn,L-ri.num,L-ri.name,L-ri.price,L-ri.count,L-ri.sale);void coun(SqList *L)int i=0,j;char num110,name130;float price1,sale1;int count1;for(i=0;itype;i+)for(j=i+1;jtype;j+)if(L-rj.countL-ri.count)strcpy(num1,L-rj.num);strcpy(L-rj.num,L-ri.num);strcpy(L-ri.num,num1);strcpy(name1,L-rj.name);strcpy(L-

12、rj.name,L-ri.name);strcpy(L-ri.name,name1);price1=L-rj.price;L-rj.price=L-ri.price;L-ri.price=price1;count1=L-rj.count;L-rj.count=L-ri.count;L-ri.count=count1;sale1=L-rj.sale;L-rj.sale=L-ri.sale;L-ri.sale=sale1;printf(t按药品编号排序后:n);printf(t药品编号 药品名称 药品单价 药品销售量 药品销售额n);for(i=0;itype;i+)printf(t %st %s

13、t %ft %dt %fn,L-ri.num,L-ri.name,L-ri.price,L-ri.count,L-ri.sale);void sales(SqList *L)int i=0,j;char num110,name130;float price1,sale1;int count1;for(i=0;itype;i+)for(j=i+1;jtype;j+)if(L-rj.saleL-ri.sale)strcpy(num1,L-rj.num);strcpy(L-rj.num,L-ri.num);strcpy(L-ri.num,num1);strcpy(name1,L-rj.name);s

14、trcpy(L-rj.name,L-ri.name);strcpy(L-ri.name,name1);price1=L-rj.price;L-rj.price=L-ri.price;L-ri.price=price1;count1=L-rj.count;L-rj.count=L-ri.count;L-ri.count=count1;sale1=L-rj.sale;L-rj.sale=L-ri.sale;L-ri.sale=sale1;printf(t按药品编号排序后:n);printf(t药品编号 药品名称 药品单价 药品销售量 药品销售额n);for(i=0;itype;i+)printf(

15、t %st %st %ft %dt %fn,L-ri.num,L-ri.name,L-ri.price,L-ri.count,L-ri.sale);void menu()printf(ttt销售记录排序n);printf(t-n);printf(t| 1)按药品编号 |n);printf(t| 2)按药品名称 |n);printf(t| 3)按药品单价 |n);printf(t| 4)按药品销售量 |n);printf(t| 5)按药品销售额 |n);printf(t| 0)退出系统 |n);printf(t-n);printf( 请选择);int main()SqList *L;int n,

16、i,m;char num110,name130;float price1,sale1;int count1;FILE *fp;L=(SqList*)malloc(sizeof(SqList);fp=fopen(medince.txt,w); /创立文件if(!fp) printf(Sorry! error!n);exit(0);printf(请输入药品种类数(type=n;for(i=0;ilength=0; fp=fopen(medince.txt,r);if(!fp) printf(Sorry! error!);exit(0);for(i=0;iri.num,L-ri.name,&L-ri

17、.price,&L-ri.count,&L-ri.sale); /从文件中读信息L-length+;fclose(fp);printf(t药品编号 药品名称 药品单价 药品销售量 药品销售额n);for(i=0;itype;i+)printf(t %st %st %ft %dt %fn,L-ri.num,L-ri.name,L-ri.price,L-ri.count,L-ri.sale);while(1) menu();scanf(%d,&m);switch(m)case 1:number(L);break;case 2:nam(L);break;case 3:pric(L);break;case 4:coun(L);break;case 5:sales(L);break;case 0:exit(0);break;default:printf(Sorry!输入有误!);break;

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 应用文书 > 工作报告

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁