药店的药品销售统计系统(排序应用_第1页
药店的药品销售统计系统(排序应用_第2页
药店的药品销售统计系统(排序应用_第3页
药店的药品销售统计系统(排序应用_第4页
药店的药品销售统计系统(排序应用_第5页
已阅读5页,还剩14页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

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

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

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

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

5、的定义DataType rmaxsize;int length;int type;SqList;void number(SqList *L) /按药品编号排序int i,j;char num110,name130;float price1,sale1;int count1;for(i=0;i<L->type;i+)for(j=i+1;j<L->type;j+)if(strcmp(L->rj.num,L->ri.num)>0) strcpy(num1,L->rj.num);strcpy(L->rj.num,L->ri.num);strc

6、py(L->ri.num,num1);strcpy(name1,L->);strcpy(L->,L->);strcpy(L->,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-&g

7、t;ri.sale;L->ri.sale=sale1;printf("t按药品编号排序后:n");printf("t药品编号 药品名称 药品单价 药品销售量 药品销售额n");for(i=0;i<L->type;i+)printf("t %st %st %ft %dt %fn",L->ri.num,L->,L->ri.price,L->ri.count,L->ri.sale);void nam(SqList *L) /按药品名称排序int i,j;char num110,n

8、ame130;float price1,sale1;int count1;for(i=0;i<L->type;i+)for(j=i+1;j<L->type;j+)if(strcmp(L->,L->)>0) strcpy(num1,L->rj.num);strcpy(L->rj.num,L->ri.num);strcpy(L->ri.num,num1);strcpy(name1,L->);strcpy(L->,L->);strcpy(L->

9、;,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药品编号 药品名称 药品单价 药品销售量 药

10、品销售额n");for(i=0;i<L->type;i+)printf("t %st %st %ft %dt %fn",L->ri.num,L->,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;i<L->type;i+)for(j=i+1;j<L->type;j+)if(L->rj

11、.price>L->ri.price)strcpy(num1,L->rj.num);strcpy(L->rj.num,L->ri.num);strcpy(L->ri.num,num1);strcpy(name1,L->);strcpy(L->,L->);strcpy(L->,name1);price1=L->rj.price;L->rj.price=L->ri.price;L->ri.price=price1;count1=L->rj.count;L

12、->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;i<L->type;i+)printf("t %st %st %ft %dt %fn",L->ri.num,L->,L->

13、;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;i<L->type;i+)for(j=i+1;j<L->type;j+)if(L->rj.count>L->ri.count)strcpy(num1,L->rj.num);strcpy(L->rj.num,L->ri.num);strcpy(L->ri.num,num1);st

14、rcpy(name1,L->);strcpy(L->,L->);strcpy(L->,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=

15、sale1;printf("t按药品编号排序后:n");printf("t药品编号 药品名称 药品单价 药品销售量 药品销售额n");for(i=0;i<L->type;i+)printf("t %st %st %ft %dt %fn",L->ri.num,L->,L->ri.price,L->ri.count,L->ri.sale);void sales(SqList *L)int i=0,j;char num110,name130;float price1,sale1;int

16、 count1;for(i=0;i<L->type;i+)for(j=i+1;j<L->type;j+)if(L->rj.sale>L->ri.sale)strcpy(num1,L->rj.num);strcpy(L->rj.num,L->ri.num);strcpy(L->ri.num,num1);strcpy(name1,L->);strcpy(L->,L->);strcpy(L->,name1);price1=L->rj.price;L-

17、>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;i<L->type;i+)

18、printf("t %st %st %ft %dt %fn",L->ri.num,L->,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)按

19、药品销售量 |n");printf("t| 5)按药品销售额 |n");printf("t| 0)退出系统 |n");printf("t-n");printf(" 请选择<05>");int main()SqList *L;int n,i,m;char num110,name130;float price1,sale1;int count1;FILE *fp;L=(SqList*)malloc(sizeof(SqList);fp=fopen("medince.txt",&q

20、uot;w"); /创建文件if(!fp) printf("Sorry! File open error!n");exit(0);printf("请输入药品种类数(<=100):");scanf("%d",&n);L->type=n;for(i=0;i<n;i+) printf("请输入该药品的编号(格式如:B125,前一位为大写字母,后三位为数字):");scanf("%s",num1);getchar();printf("请输入该药品的名称:&q

21、uot;);scanf("%s",name1);getchar();printf("请输入该药品的单价:");scanf("%f",&price1);printf("请输入该药品的销售量:");scanf("%d",&count1); getchar();sale1=price1*count1;fprintf(fp,"%st%st%ft%dt%fn",num1,name1,price1,count1,sale1);printf("n");fclose(fp);L->length=0; f

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论