药店的药品销售统计系统082644.docx

上传人:b****4 文档编号:27243787 上传时间:2023-06-28 格式:DOCX 页数:17 大小:98.69KB
下载 相关 举报
药店的药品销售统计系统082644.docx_第1页
第1页 / 共17页
药店的药品销售统计系统082644.docx_第2页
第2页 / 共17页
药店的药品销售统计系统082644.docx_第3页
第3页 / 共17页
药店的药品销售统计系统082644.docx_第4页
第4页 / 共17页
药店的药品销售统计系统082644.docx_第5页
第5页 / 共17页
点击查看更多>>
下载资源
资源描述

药店的药品销售统计系统082644.docx

《药店的药品销售统计系统082644.docx》由会员分享,可在线阅读,更多相关《药店的药品销售统计系统082644.docx(17页珍藏版)》请在冰豆网上搜索。

药店的药品销售统计系统082644.docx

药店的药品销售统计系统082644

设计题目

[问题描述]

设计一系统,实现医药公司定期对销售各药品的记录进行统计,可按药品的编号、单

价、销售量或销售额做出排名。

需求分析

药品的销售统计是在利用电脑的实现生活中的需求,在如今医疗事业蓬勃的发展下,药店的药品数目也日益的增多,根据社会的需求,在这种大潮的推动力下药店药品的销售管理系统成了迫切的需要,在这种大前提下,我们实现了这样的系统来完成药品的销售统计。

今年来,药品零售业的格局,出现了很大的变化医药改革为零售药房,特别是为连锁药房提供了广阔的发展空间。

医药企业自身发展也提出了自身发展也提出了改革的要求。

集团化、代理制等形式的出现打破了过去暗地域行政区划分设立的医药流通格局,重批发轻工业零售的传统观念正随着改革的深入而逐步发生着变化,特别是医药零售行业早已打破了过去那种国有医药一统天下的局面,这也迫使许多医药企业纷纷适应市场变化的要求进行零分设的改革,利用原有医药零售网店的基础建设建立连锁药房,这即成为医药企业改革噶站的必然热点,有形成这些企业参与市场竞争的经济增长点,再这样的大环境之下,药店基本现状有很多情况。

、药店的功能和经验重点发生了根本性的转变。

、药店的布局不合理。

各地药店纷纷开业,甚至出现了有点多过于米店的局面,并

且出现了扎堆经营的现象。

三、药店规模相对偏小,缺乏市场竞争力。

四、陷入评价竞争的泥潭,低层次的价格竞争,使很多药店到了举步维艰的地步。

五、药店经营成本在提高,利润在下降。

六、企业整体服务意识淡薄,从业人员缺乏专业素质。

因为这些现状,药店销售管理系统的研发也是迫在眉睫,目前市场上拥有的各种系统软件也因为药店这样的状况,而存在相同的状况。

算法设计

1.算法思想

在本设计中,首先从数据文件中读出各药品的信息记录,存储在顺序表中。

各药品

4位,

的信息包括:

药品编号、药名、药品单价、销出数量、销售额。

药品编号共采用字母和数字混合编号,如:

A125,前一位为大写字母,后三位为数字,按药品编号进行排序时,可采用基数排序法。

对各药品的单价、销售量或销售额进行排序时,可采用多种排序方法,如直接插入排序、冒泡排序、快速排序,直接选择排序等方法。

在本设计中,对单价的排序采用冒泡排序法,对销售量的排序采用快速排序法,对销售额的排序采用堆排序法。

药品信息的元素类型定义:

typedefstructnode

 

{charnum[4];/*

药品编号*/

charname[10];/*

药品名称*/

floatprice;/*

药品单价*/

 

floatsale;/*本药品销售额*/}DataType;

存储药品信息的顺序表的定义:

typedefstruct{DataTyper[MaxSize];

intlength;

}SequenList;

2.算法设计分析

首先从txt文件中读取数据信息并保存,本次试验采用了5中排序方法。

其中编号排序是按照基数排序,采用多关键字进行排序。

基数排序是借助“分配”和“收集”两种操作对单逻辑关键字进行排序的一种内排序方法。

对单价的排序采用了直接插入排序和冒泡排序,直接插入排序就是首先将第一个元素看成是一个有序的,然后第二个元素和第一个比较,若大于第一个则放在其后面否则放前面,依次直至最后一个。

冒泡排序就是采用两个循环,即将第一个元素和第二个比较若第一个大于第二个则交换,否则不变,然后第二个和第三个比较,同上。

第一趟可将最大的一个放在最后,依次可得排序。

销售量是快速排序,快速排序就是首先设置一个关键字,然后让最后一个和其比较,直至找到一个比关键字小的,然后和其交换,接

来让第一个和其比较,直至找到一个比其大的,然后交换,在找到的位置分别做标记,依次执行即可。

销售额使用的是堆排序,堆排序首先要建立一个完全二叉树的堆,其标准符合为父节点始终比子节点大。

然后依次输出顶结点,然后在建立一个符合标准的堆重复操作即可。

3.流程图

 

四、

调试分析与结果

 

灵*C:

UJoDUM^t^emdSettuL^aXAdMinia-tra-fDT\Debuck^^)4坏21日.mu

nH>x式D

Au£5-■

u>編容单销的的旳囱U雪書E口F誓药葯该决诀谯入人入入请请请话

ti一位为大弓亍耳.后三位为数T^:

pw2

武C—

爭辰_

4|称£

垢窑聶

目9忖闪

.逆迪耶

住曙

前一位为大写字号,后三位珈字〉:

曲™主

加01

H»(K

nnni

输入药品的信息

n'eiUkiii—PBi*-兵

XHL

nwa

AWJ

OWE!

flSD

ran'

:

曹品单价

se.eoseea

L5.UUWUI30.wiHmn館哥F对貯

药品箱售量药.£■哺售疝

L£Se.900909

Z4tKI,WUW«

Ttn.nRon腼

uu斤£

董断号品品品品nm系

--J--RJJ—^1■>,>>>>

1z31bfl

wnss-二蚩同£安两境丸竜eJ

轴E

MB

4>

5->

">

玮a卑*

U.M4M4riS.WHHHi;WWW

按药品的编号。

药*5量

iS

咼品请Saa

LK4.MI4Ma-MwiiMffJ如枷删

 

X■C;\DocLii.tffitJMidStttj_uVAaIaiaiBl1utor\DtfLLie6ai#

BBD

Nl

号稲f星H出ngiigza田耶

-i.>>>>>■>■Iz34b■

淸己择<(r£〉2

感药(&君诽经F启:

亦肓晶客称药后单暫£XC4UF

A&P

药岳壕°

AGS]

lcfi#l

PVIB

Ib.lWAIWl

药品和豊狂药吕羽&

66

2b

1砒

33a.e^0tia

12E>«.#iKii*i

■V+Ttrt-I

Ir-llpitti2单齧琉QESns迄口累>>■>>>>123^5a

VBB-r

 

 

按药品的名称。

卞"dDoCLiABEMMidSttlLat^\AdAIAlBlIutDX.\DtrLLlc\^^JF2L^.Bltf

斜兰记录排手

一盖一春童層出ngugzacg耶>>>>>>■

 

适迂FKd

按药品的销售额。

 

五、

课设总结

八、

附录(源代码)

 

 

#includevstdio.h>

#include

#include

 

charnum[10];//

药品编号

charname[30];

floatprice;//

单价

intcount;//

销售量

floatsale;//

销售额

}DataType;

typedefstruct//

存储药品信息的顺序表的定义

DataTyper[maxsize];

intlength;

inttype;

}SqList;

voidnumber(SqList*L)//

按药品编号排序

inti,j;

charnum1[10],name1[30];

floatprice1,sale1;

intcount1;

for(i=0;itype;i++)//

循环

for(j=i+1;jtype;j++)

if(strcmp(L->r[j].num,L->r[i].num)>0)//

判断两个数的大小,

{strcpy(num1,L->r[j].num);

strcpy(L->r[j].num,L->r[i].num);

strcpy(L->r[i].num,num1);

 

strcpy(name1,L->r[j].name);

strcpy(L->r[j].name,L->r[i].name);

strcpy(L->r[i].name,name1);

price1=L->r[j].price;

L->r[j].price=L->r[i].price;

L->r[i].price=price1;

count1=L->r[j].count;

L->r[j].count=L->r[i].count;

L->r[i].count=count1;

sale1=L->r[j].sale;

L->r[j].sale=L->r[i].sale;

L->r[i].sale=sale1;

printf("\t

药品编号药品名称药品单价药品销售量药品销售额

 

\n");

 

 

for(i=0;itype;i++)

printf("\t%s\t%s\t%f\t%d\t%f\n",L->r[i].num,L->r[i].name,L->r[i]

.price,L->r[i].count,L->r[i].sale);

inti,j;

charnum1[10],name1[30];

floatprice1,sale1;

intcount1;

for(i=0;itype;i++)

for(j=i+1;jtype;j++)

if(strcmp(L->r[j].name,L->r[i].name)>0){strcpy(num1,L->r[j].num);

strcpy(L->r[j].num,L->r[i].num);

strcpy(L->r[i].num,num1);

strcpy(name1,L->r[j].name);

strcpy(L->r[j].name,L->r[i].name);

strcpy(L->r[i].name,name1);

price1=L->r[j].price;

L->r[j].price=L->r[i].price;

L->r[i].price=price1;

L->r[i].count=count1;

sale1=L->r[j].sale;

L->r[j].sale=L->r[i].sale;

L->r[i].sale=sale1;

 

printf("\t

\n");

for(i=0;itype;i++)

printf("\t%s\t%s\t%f\t%d\t%f\n",L->r[i].num,L->r[i].name,L->r[i]

.price,L->r[i].count,L->r[i].sale);

药品编号药品名称药品单价药品销售量药品销售额

inti=0,j;

charnum1[10],name1[30];

floatprice1,sale1;

intcount1;

for(i=0;itype;i++)

for(j=i+1;jtype;j++)

if(L->r[j].price>L->r[i].price){strcpy(num1,L->r[j].num);

strcpy(L->r[j].num,L->r[i].num);

strcpy(L->r[i].num,num1);

strcpy(L->r[i].name,name1);

price1=L->r[j].price;

L->r[j].price=L->r[i].price;

L->r[i].price=price1;

count1=L->r[j].count;

L->r[j].count=L->r[i].count;

L->r[i].count=count1;

sale1=L->r[j].sale;

L->r[j].sale=L->r[i].sale;

L->r[i].sale=sale1;

printf("\t按药品单价排序后:

\n");

printf("\t

药品编号药品名称药品单价药品销售量药品销售额

 

\n");

for(i=0;itype;i++)

 

printf("\t%s\t%s\t%f\t%d\t%f\n",L->r[i].num,L->r[i].name,L->r[i]

.price,L->r[i].count,L->r[i].sale);

inti=0,j;

charnum1[10],name1[30];

floatprice1,sale1;

intcount1;

for(i=0;itype;i++)

for(j=i+1;jtype;j++)

strcpy(L->r[j].num,L->r[i].num);

strcpy(L->r[i].num,num1);

strcpy(name1,L->r[j].name);

strcpy(L->r[j].name,L->r[i].name);

strcpy(L->r[i].name,name1);

price1=L->r[j].price;

L->r[j].price=L->r[i].price;

L->r[i].price=price1;

count1=L->r[j].count;

L->r[j].count=L->r[i].count;

L->r[i].count=count1;

L->r[i].sale=sale1;

 

printf("\t

\n");

for(i=0;itype;i++)

printf("\t%s\t%s\t%f\t%d\t%f\n",L->r[i].num,L->r[i].name,L->r[i]

.price,L->r[i].count,L->r[i].sale);

inti=0,j;

charnum1[10],name1[30];

药品编号药品名称药品单价药品销售量药品销售额

floatprice1,sale1;

intcount1;

for(i=0;itype;i++)

for(j=i+1;jtype;j++)

if(L->r[j].sale>L->r[i].sale){strcpy(num1,L->r[j].num);

strcpy(L->r[j].num,L->r[i].num);

strcpy(L->r[i].num,num1);

strcpy(name1,L->r[j].name);

strcpy(L->r[j].name,L->r[i].name);

strcpy(L->r[i].name,name1);

L->r[i].price=price1;

count1=L->r[j].count;

L->r[j].count=L->r[i].count;

L->r[i].count=count1;

sale1=L->r[j].sale;

L->r[j].sale=L->r[i].sale;

L->r[i].sale=sale1;

 

printf("\t

药品编号药品名称药品单价药品销售量药品销售额

 

\n");

 

 

for(i=0;itype;i++)

printf("\t%s\t%s\t%f\t%d\t%f\n",L->r[i].num,L->r[i].name,L->r[i].price,L->r[i].count,L->r[i].sale);

voidmenu()

printf("\t\t\t

销售记录排序\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("

请选择<0~5>");

main()

SqList*L;

intn,i,m;

charnum1[10],name1[30];

floatprice1,sale1;

intcount1;

FILE*fp;

创建文件

L=(SqList*)malloc(sizeof(SqList));

fp=fopen("medince.txt","w");//

if(!

fp){printf("Sorry!

Fileopenerror!

\n");exit(0);}

printf("请输入药品种类数(<=100):

");

scanf("%d",&n);

L->type=n;

for(i=0;i

数字):

");

scanf("%s",num1);

getchar();

 

scanf("%s",name1);

getchar();

 

scanf("%f",&price1);

printf("请输入该药品的销售量:

");

scanf("%d",&count1);getchar();

fprintf(fp,"%s\t%s\t%f\t%d\t%f\n",num1,name1,price1,count1,sale1);

printf("\n");

fclose(fp);//

关闭文件

 

 

L->length=0;

fp=fopen("medince.txt","r");

if(!

fp){printf("Sorry!

Fileopenerror!

");exit(0);}

for(i=0;i

从文件中读信息

fscanf(fp,"%s\t%s\t%f\t%d\t%f\n",L->r[i].num,L->r[i].name,&L->r[i].price,&

L->r[i].count,&L->r[i].sale);//

L->length++;

fclose(fp);

printf("\t药品编号药品名称药品单价药品销售量药品销售额\n");

for(i=0;itype;i++)printf("\t%s\t%s\t%f\t%d\t%f\n",L->r[i].num,L->r[i].name,L->r[i].price,L->r[i].count,L->r[i].sale);

while

(1)//循环结构

{menu();

scanf("%d",&m);

switch(m)

case1:

number(L);break;

case2:

nam(L);break;

case3:

pric(L);break;

case4:

coun(L);break;

case5:

sales(L);break;

case0:

exit(0);break;

default:

printf("

抱歉!

输入有误,请重新输入~~");break;

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 总结汇报 > 学习总结

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1