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

下载本文档

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

文档简介

1、文档编码 : CN1E3R4D8R8 HL4V8J4H5X4 ZV4V8G9C10F6学习资料收集于网络,仅供参考试验五 药店的药品销售统计系统(排序应用)一、试验目的1. 帮忙读者复习 C+语言程序设计中的学问;2. 对数据进行排序时,可接受多种排序方法,如直接插入排序、冒泡排序、快速排序,直接选择排序等方法的实现; 需求分析 设计一系统, 实现医药公司定期对销售各药品的记录进行统计,可按药品的编号、 单价、销售量或销售额做出排名;二、试验内容和要求 问题要求 设计一系统,实现医药公司定期对销售各药品的记录进行统计,可按药品的编号、单价、销售量或销售额做出排名; 问题分析 在本设计中,第一从

2、数据文件中读出各药品的信息记录,储备在次序表中;各药品的信息包括:药品编号、药名、药品单价、销出数量、销售额;药品编号共 4 位,接受字母和数字混合编号,如:125,前一位为大写字母,后三位为 12 数字,按药品编号进行排序时,可接受基数排序法;对各药品的单价、销售量或销售额进行排序时,可接受多种排序方法,如直接插入排序、冒泡排序、快速排序,直接选择排序等方法;在本设计中,对单价的排序接受冒泡排序法,对销售量的排序接受快速排序法,对销售额的排序接受堆排序法;三、算法设计第一从 txt文件中读取数据信息并储存,本次试验接受了5 中排序方法;其中编号排序是依据基数排序,接受多关键字进行排序;基数排

3、序是借助“ 支配” 和“ 收集” 两种操作 对单规律关键字进行排序的一种内排序方法;对单价的排序接受了直接插入排序和冒泡排 序,直接插入排序就是第一将第一个元素看成是一个有序的,然后其次个元素和第一个比 较,如大于第一个就放在其后面否就放前面,依次直至最终一个;冒泡排序就是接受两个 循环,即将第一个元素和其次个比较如第一个大于其次个就交换,否就不变,然后其次个 和第三个比较,同上;第一趟可将最大的一个放在最终,依次可得排序;销售量是快速排 序,快速排序就是第一设置一个关键字,然后让最终一个和其比较,直至找到一个比关键 字小的,然后和其交换,接下来让第一个和其比较,直至找到一个比其大的,然后交换

4、,在找到的位置分别做标记,依次执行即可;销售额使用的是堆排序,堆排序第一要建立一 个完全二叉树的堆,其标准符合为父节点始终比子节点大;然后依次输出顶结点,然后在 建立一个符合标准的堆重复操作即可;四、调试分析及数据测试输入药品学习资料学习资料收集于网络,仅供参考五、测试结果学习资料学习资料收集于网络,仅供参考测试结果符合程序写作要求#include #include #include #define maxsize 100 / typedef struct node / DataType; 该医药公司药品最大种类药品信息的储备结构类型定义char num10; / 药品编号char name3

5、0; float price; / 单价int count; / 销售量float sale; / 销售额typedef struct / 储备药品信息的次序表的定义 DataType rmaxsize; int length; 学习资料学习资料收集于网络,仅供参考int type; SqList; void numberSqList *L / i.num0 ; .num; 学习资料按药品编号排序int i,j; char num110,name130; float price1,sale1; int count1; fori=0;itype;i+ forj=i+1;jtype;j+ ifst

6、rcmpL-rj.num,L-r strcpynum1,L-rj.numstrcpyL-rj.num,L-ristrcpyL-ri.num,num1; 学习资料收集于网络,仅供参考strcpyname1,L- ; strcpyL-,L-ri .name; strcpyL-,name1 ; price1=L-rj.price; L-rj.price=L-ri.pric e; L-ri.price=price1; count1=L-rj.count; L-rj.count=L-ri.coun t; L-ri.count=count1; sale1=L-rj

7、.sale; L-rj.sale=L-ri.sale; L-ri.sale=sale1; 学习资料学习资料收集于网络,仅供参考 printft 按 药 品 编 号 排 序 后:n; 称药品单价药品销售量printft药品编号药品名药品销售额 n; fori=0;itype;i+ printft %st %st %f t %dt %fn,L-ri.num,L-,L-ri.price,L- ri.count,L-ri.sale; void namSqList *L / 按药品名称排序 int i,j; char num110,name130; float price1,sale1;

8、int count1; fori=0;itype;i+ 学习资料学习资料收集于网络,仅供参考 forj=i+1;jtype;j+ ifstrcmpL-,L- 0 strcpynum1,L-rj.num ; strcpyL-rj.num,L-ri .num; strcpyL-ri.num,num1; strcpyname1,L- ; strcpyL-,L-ri .name; strcpyL-,name1 ; price1=L-rj.price; L-rj.price=L-ri.pric e; 学习资料学习资料收集于网络,仅供参

9、考L-ri.price=price1; count1=L-rj.count; L-rj.count=L-ri.coun t; L-ri.count=count1; sale1=L-rj.sale; L-rj.sale=L-ri.sale; L-ri.sale=sale1; printft 按 药 品 编 号 排 序后:n; 称药品单价药品销售量printft药品编号药品名药品销售额 n; fori=0;itype;i+ printft %st %st %f t %dt %fn,L-ri.num,L-,L-ri.price,L- ri.count,L-ri.sale; 学习资料学习

10、资料收集于网络,仅供参考 void pricSqList *L int i=0,j; char num110,name130; float price1,sale1; int count1; fori=0;itype;i+ forj=i+1;jtype;j+ ifL-rj.priceL-ri.p rice strcpynum1,L-rj.num; strcpyL-rj.num,L-ri .num; strcpyL-ri.num,num1; 学习资料学习资料收集于网络,仅供参考strcpyname1,L- ; strcpyL-,L-ri .name; strcpyL-

11、,name1 ; price1=L-rj.price; L-rj.price=L-ri.pric e; L-ri.price=price1; count1=L-rj.count; L-rj.count=L-ri.coun t; L-ri.count=count1; sale1=L-rj.sale; L-rj.sale=L-ri.sale; L-ri.sale=sale1; 学习资料学习资料收集于网络,仅供参考printft 按 药 品 编 号 排 序后:n; 称药品单价药品销售量printft药品编号药品名药品销售额 n; fori=0;itype;i+ printft %st

12、%st %f t %dt %fn,L-ri.num,L-,L-ri.price,L- ri.count,L-ri.sale; void counSqList *L int i=0,j; char num110,name130; float price1,sale1; int count1; fori=0;itype;i+ 学习资料学习资料收集于网络,仅供参考 forj=i+1;jtype;j+ ifL-rj.countL-ri.c ount strcpynum1,L-rj.num; strcpyL-rj.num,L-ri .num; strcpyL-ri.num,num1; st

13、rcpyname1,L- ; strcpyL-,L-ri .name; strcpyL-,name1 ; price1=L-rj.price; L-rj.price=L-ri.pric e; L-ri.price=price1; 学习资料学习资料收集于网络,仅供参考count1=L-rj.count; L-rj.count=L-ri.coun t; L-ri.count=count1; sale1=L-rj.sale; L-rj.sale=L-ri.sale; L-ri.sale=sale1; printft 按 药 品 编 号 排 序 后:n; 称药

14、品单价药品销售量printft药品编号药品名药品销售额 n; fori=0;itype;i+ printft %st %st %f t %dt %fn,L-ri.num,L-,L-ri.price,L- ri.count,L-ri.sale; 学习资料学习资料收集于网络,仅供参考void salesSqList *L int i=0,j; char num110,name130; float price1,sale1; int count1; fori=0;itype;i+ forj=i+1;jtype;j+ ifL-rj.saleL-ri.sa le strcpynum1,L-

15、rj.num; strcpyL-rj.num,L-ri .num; strcpyL-ri.num,num1; strcpyname1,L-学习资料学习资料收集于网络,仅供参考; strcpyL-,L-ri .name; strcpyL-,name1 ; price1=L-rj.price; L-rj.price=L-ri.pric e; L-ri.price=price1; count1=L-rj.count; L-rj.count=L-ri.coun t; L-ri.count=count1; sale1=L-rj.sale; L-rj.sale=L

16、-ri.sale; L-ri.sale=sale1; printft 按 药 品 编 号 排 序学习资料学习资料收集于网络,仅供参考后:n; 称药品单价药品销售量printft药品编号药品名药品销售额 n; fori=0;itype;i+ printft %st %st %f t %dt %fn,L-ri.num,L-,L-ri.price,L- ri.count,L-ri.sale; void menu printfttt 销售记录排序 n; printft-n; printft| 1 按药品编号 |n; printft| 2 按药 品名称 |n; printft| 3 按药学

17、习资料学习资料收集于网络,仅供参考品单价 |n; printft| 4 按药 品销售量 |n; printft| 5 按药 品销售额 |n; printft| 0 退出 系统 |n; printft-n; printf 请 选 择 ; int main SqList *L; int n,i,m; char num110,name130; float price1,sale1; int count1; FILE *fp; 学习资料学习资料收集于网络,仅供参考L=SqList*mallocsizeofS qList; fp=fopenmedince.txt,w; /创建文件if.fp printf

18、Sorry. File open error.n;exit0; printf 请 输 入 药 品 种 类 数 type=n; fori=0;ilength=0; fp=fopenmedince.txt,r ; if.fp printfSorry. File open error.;exit0; fori=0;iri.num,L-,&L-ri.price,&L-ri.co unt,&L-ri.sale; / 从文件中读信息 L-length+; fclosefp; 称药品单价药品销售量printft药品编号药品名药品销售额 n; fori=0;itype;i+ printft %s

温馨提示

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

评论

0/150

提交评论