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





《药店的药品销售统计系统排序应用.pdf》由会员分享,可在线阅读,更多相关《药店的药品销售统计系统排序应用.pdf(19页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、-实验五实验五 药店的药品销售统计系统(排序应用)药店的药品销售统计系统(排序应用)一、实验目的一、实验目的1.1.帮助读者复习帮助读者复习 C+C+语言程序设计中的知识。语言程序设计中的知识。2.2.对数据进行排序时,可采用多种排序方法,如直接插入排序、冒泡排序、快对数据进行排序时,可采用多种排序方法,如直接插入排序、冒泡排序、快速排序,直接选择排序等方法的实现。速排序,直接选择排序等方法的实现。需求分析需求分析 设计一系统,设计一系统,实现医药公司定期对销售各药品的记录进行统计,实现医药公司定期对销售各药品的记录进行统计,可按药品的编号、可按药品的编号、单价、单价、销售量或销售额做出排名。
2、销售量或销售额做出排名。二、实验内容和要求二、实验内容和要求 问题要求问题要求 设计一系统,实现医药公司定期对销售各药品的记录进行统计,可按药品的编号、单设计一系统,实现医药公司定期对销售各药品的记录进行统计,可按药品的编号、单价、销售量或销售额做出排名。价、销售量或销售额做出排名。问题分析问题分析 在本设计中,首先从数据文件中读出各药品的信息记录,存储在顺序表中。各药品的在本设计中,首先从数据文件中读出各药品的信息记录,存储在顺序表中。各药品的信息包括:药品编号、药名、药品单价、销出数量、销售额。药品编号共信息包括:药品编号、药名、药品单价、销出数量、销售额。药品编号共 4 4 位,采用字母
3、位,采用字母和数字混合编号,如:和数字混合编号,如:125125,前一位为大写字母,后三位为,前一位为大写字母,后三位为 1212 数字,按药品编号进行排序数字,按药品编号进行排序时,可采用基数排序法。对各药品的单价、销售量或销售额进行排序时,可采用多种排序时,可采用基数排序法。对各药品的单价、销售量或销售额进行排序时,可采用多种排序方法,如直接插入排序、冒泡排序、快速排序,直接选择排序等方法。在本设计中,对单方法,如直接插入排序、冒泡排序、快速排序,直接选择排序等方法。在本设计中,对单价的排序采用冒泡排序法,对销售量的排序采用快速排序法,对销售额的排序采用堆排序价的排序采用冒泡排序法,对销售
4、量的排序采用快速排序法,对销售额的排序采用堆排序法。法。三、算法设计三、算法设计首先从首先从 txttxt 文件中读取数据信息并保存,本次试验采用了文件中读取数据信息并保存,本次试验采用了 5 5 中排序方法。其中编号排序中排序方法。其中编号排序是按照基数排序,采用多关键字进行排序。基数排序是借助“分配”和“收集”两种操作是按照基数排序,采用多关键字进行排序。基数排序是借助“分配”和“收集”两种操作对单逻辑关键字进行排序的一种内排序方法。对单价的排序采用了直接插入排序和冒泡排对单逻辑关键字进行排序的一种内排序方法。对单价的排序采用了直接插入排序和冒泡排序,直接插入排序就是首先将第一个元素看成是
5、一个有序的,然后第二个元素和第一个比序,直接插入排序就是首先将第一个元素看成是一个有序的,然后第二个元素和第一个比较,若大于第一个则放在其后面否则放前面,依次直至最后一个。冒泡排序就是采用两个较,若大于第一个则放在其后面否则放前面,依次直至最后一个。冒泡排序就是采用两个循环,即将第一个元素和第二个比较若第一个大于第二个则交换,否则不变,然后第二个循环,即将第一个元素和第二个比较若第一个大于第二个则交换,否则不变,然后第二个和第三个比较,同上。第一趟可将最大的一个放在最后,依次可得排序。销售量是快速排和第三个比较,同上。第一趟可将最大的一个放在最后,依次可得排序。销售量是快速排序,快速排序就是首
6、先设置一个关键字,然后让最后一个和其比较,直至找到一个比关键序,快速排序就是首先设置一个关键字,然后让最后一个和其比较,直至找到一个比关键字小的,然后和其交换,接下来让第一个和其比较,直至找到一个比其大的,然后交换,字小的,然后和其交换,接下来让第一个和其比较,直至找到一个比其大的,然后交换,在找到的位置分别做标记,依次执行即可。销售额使用的是堆排序,堆排序首先要建立一在找到的位置分别做标记,依次执行即可。销售额使用的是堆排序,堆排序首先要建立一个完全二叉树的堆,其标准符合为父节点始终比子节点大。然后依次输出顶结点,然后在个完全二叉树的堆,其标准符合为父节点始终比子节点大。然后依次输出顶结点,
7、然后在建立一个符合标准的堆重复操作即可。建立一个符合标准的堆重复操作即可。四、调试分析及数据测试四、调试分析及数据测试-.可修编.-输入药品输入药品五、测试结果五、测试结果-.可修编.-测试结果符合程序写作要求测试结果符合程序写作要求#include#include#include#include#include#include#define maxsize 100/#define maxsize 100/该医药公司药品最大种类该医药公司药品最大种类typedef struct nodetypedef struct node/药品信息的存储结构类型定义药品信息的存储结构类型定义 DataTyp
8、e;DataType;typedef structtypedef struct/存储药品信息的顺序表的定义存储药品信息的顺序表的定义 DataType rmaxsize;DataType rmaxsize;int length;int length;char num10;/char num10;/药品编号药品编号char name30;char name30;float price;/float price;/单价单价intintcount;/count;/销售量销售量float sale;/float sale;/销售额销售额-.可修编.-SqList;SqList;intinttype;t
9、ype;void number(SqList*L)void number(SqList*L)/按药品编号排序按药品编号排序 m)0)m)0)-int i,j;int i,j;char num110,name130;char num110,name130;float price1,sale1;float price1,sale1;int count1;int count1;for(i=0;itype;i+)for(i=0;itype;i+)for(j=i+1;jtype;j+)for(j=i+1;jtype;j+)if(strcmp(L-rj.num,L-ri.nuif(strcmp(L-rj.
10、num,L-ri.nu strcpy(num1,L-rj.num);strcpy(num1,L-rj.num);strcpy(L-rj.num,L-ri.num);strcpy(L-rj.num,L-ri.num);strcpy(L-ri.num,num1);strcpy(L-ri.num,num1);strcpy(name1,L-rj.name);strcpy(name1,L-rj.name);.可修编.-););药品单价药品单价-药品销售量药品销售量strcpy(L-rj.name,L-ri.namestrcpy(L-rj.name,L-ri.namestrcpy(L-ri.name,na
11、me1);strcpy(L-ri.name,name1);price1=L-rj.price;price1=L-rj.price;L-rj.price=L-ri.price;L-rj.price=L-ri.price;L-ri.price=price1;L-ri.price=price1;count1=L-rj.count;count1=L-rj.count;L-rj.count=L-ri.count;L-rj.count=L-ri.count;L-ri.count=count1;L-ri.count=count1;sale1=L-rj.sale;sale1=L-rj.sale;L-rj.sa
12、le=L-ri.sale;L-rj.sale=L-ri.sale;L-ri.sale=sale1;L-ri.sale=sale1;printf(tprintf(t 按药品编号排序后按药品编号排序后:n);:n);printf(tprintf(t 药品编号药品编号药品名称药品名称药品销售额药品销售额n);n);for(i=0;itype;i+)for(i=0;itype;i+).可修编.-printf(tprintf(t%st%st%st%st%ft%ft%dtdt%fn,L-ri.num,L-ri.name,L-ri.price,L-ri.count,L-ri.sa%fn,L-ri.num,L
13、-ri.name,L-ri.price,L-ri.count,L-ri.sale);le);void nam(SqList*L)void nam(SqList*L)me)0)me)0)-/按药品名称排序按药品名称排序int i,j;int i,j;char num110,name130;char num110,name130;float price1,sale1;float price1,sale1;int count1;int count1;for(i=0;itype;i+)for(i=0;itype;i+)for(j=i+1;jtype;j+)for(j=i+1;jtype;j+)if(s
14、trcmp(L-rj.name,L-ri.naif(strcmp(L-rj.name,L-ri.na strcpy(num1,L-rj.num);strcpy(num1,L-rj.num);.可修编.-););-strcpy(L-rj.num,L-ri.num);strcpy(L-rj.num,L-ri.num);strcpy(L-ri.num,num1);strcpy(L-ri.num,num1);strcpy(name1,L-rj.name);strcpy(name1,L-rj.name);strcpy(L-rj.name,L-ri.namestrcpy(L-rj.name,L-ri.na
15、mestrcpy(L-ri.name,name1);strcpy(L-ri.name,name1);price1=L-rj.price;price1=L-rj.price;L-rj.price=L-ri.price;L-rj.price=L-ri.price;L-ri.price=price1;L-ri.price=price1;count1=L-rj.count;count1=L-rj.count;L-rj.count=L-ri.count;L-rj.count=L-ri.count;L-ri.count=count1;L-ri.count=count1;sale1=L-rj.sale;sa
16、le1=L-rj.sale;L-rj.sale=L-ri.sale;L-rj.sale=L-ri.sale;L-ri.sale=sale1;L-ri.sale=sale1;printf(tprintf(t 按药品编号排序后按药品编号排序后:n);:n);.可修编.-printf(tprintf(t 药品编号药品编号药品名称药品名称药品单价药品单价药品销售量药品销售量药品销售额药品销售额n);n);printf(tprintf(t%st%st%st%st%ft%ft%for(i=0;itype;i+)for(i=0;itype;i+)dtdt%fn,L-ri.num,L-ri.name,L-ri
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 药店 药品 销售 统计 系统 排序 应用

限制150内