药店的药品销售统计系统.docx
- 文档编号:14397762
- 上传时间:2023-06-23
- 格式:DOCX
- 页数:17
- 大小:92.95KB
药店的药品销售统计系统.docx
《药店的药品销售统计系统.docx》由会员分享,可在线阅读,更多相关《药店的药品销售统计系统.docx(17页珍藏版)》请在冰点文库上搜索。
药店的药品销售统计系统
一、设计题目
[问题描述]设计一系统,实现医药公司定期对销售各药品的记录进行统计,可按药品的编号、单价、销售量或销售额做出排名。
二、需求分析
药品的销售统计是在利用电脑的实现生活中的需求,在如今医疗事业蓬勃的发展下,药店的药品数目也日益的增多,根据社会的需求,在这种大潮的推动力下药店药品的销售管理系统成了迫切的需要,在这种大前提下,我们实现了这样的系统来完成药品的销售统计。
今年来,药品零售业的格局,出现了很大的变化医药改革为零售药房,特别是为连锁药房提供了广阔的发展空间。
医药企业自身发展也提出了自身发展也提出了改革的要求。
集团化、代理制等形式的出现打破了过去暗地域行政区划分设立的医药流通格局,重批发轻工业零售的传统观念正随着改革的深入而逐步发生着变化,特别是医药零售行业早已打破了过去那种国有医药一统天下的局面,这也迫使许多医药企业纷纷适应市场变化的要求进行零分设的改革,利用原有医药零售网店的基础建设建立连锁药房,这即成为医药企业改革噶站的必然热点,有形成这些企业参与市场竞争的经济增长点,再这样的大环境之下,药店基本现状有很多情况。
一、药店的功能和经验重点发生了根本性的转变。
二、药店的布局不合理。
各地药店纷纷开业,甚至出现了有点多过于米店的局面,并且出现了扎堆经营的现象。
三、药店规模相对偏小,缺乏市场竞争力。
四、陷入评价竞争的泥潭,低层次的价格竞争,使很多药店到了举步维艰的地步。
五、药店经营成本在提高,利润在下降。
六、企业整体服务意识淡薄,从业人员缺乏专业素质。
因为这些现状,药店销售管理系统的研发也是迫在眉睫,目前市场上拥有的各种系统软件也因为药店这样的状况,而存在相同的状况。
三、算法设计
1.算法思想在本设计中,首先从数据文件中读出各药品的信息记录,存储在顺序表中。
各药品的信息包括:
药品编号、药名、药品单价、销出数量、销售额。
药品编号共4位,采用字母和数字混合编号,如:
A125,前一位为大写字母,后三位为数字,按药品编号进行排序时,可采用基数排序法。
对各药品的单价、销售量或销售额进行排序时,可采用多种排序方法,如直接插入排序、冒泡排序、快速排序,直接选择排序等方法。
在本设计中,对单价的排序采用冒泡排序法,对销售量的排序采用快速排序法,对销售额的排序采用堆排序法。
药品信息的元素类型定义:
typedefstructnode{charnum[4];/*药品编号*/charname[10];/*药品名称*/floatprice;/*药品单价*/intcount;/*销售数量*/
floatsale;/*本药品销售额*/
}DataType;
存储药品信息的顺序表的定义:
typedefstruct
{DataTyper[MaxSize];
intlength;
}SequenList;
2.算法设计分析
首先从txt文件中读取数据信息并保存,本次试验采用了5中排序方法。
其中编号排序是按照基数排序,采用多关键字进行排序。
基数排序是借助“分配”和“收集”两种操作对单逻辑关键字进行排序的一种内排序方法。
对单价的排序采用了直接插入排序和冒泡排序,直接插入排序就是首先将第一个元素看成是一个有序的,然后第二个元素和第一个比较,若大于第一个则放在其后面否则放前面,依次直至最后一个。
冒泡排序就是采用两个循环,即将第一个元素和第二个比较若第一个大于第二个则交换,否则不变,然后第二个和第三个比较,同上。
第一趟可将最大的一个放在最后,依次可得排序。
销售量是快速排序,快速排序就是首先设置一个关键字,然后让最后一个和其比较,直至找到一个比关键字小的,然后和其交换,接下来让第一个和其比较,直至找到一个比其大的,然后交换,在找到的位置分别做标记,依次执行即可。
销售额使用的是堆排序,堆排序首先要建立一个完全二叉树的堆,其标准符合为父节点始终比子节点大。
然后依次输出顶结点,然后在建立一个符合标准的堆重复操作即可。
3.流程图
四、调试分析与结果
请选華旷“
前一位为大写宇母,启三位为数宇〉油BOM
前T为大弓了可后三位为数〒*F0M
药昂編号帕01阿92Hom
:
药品单術
SO.GBBBBa
12^0.908968
Z4叫如◎卿即
药耳g称
QVEI
ASD
73CC
-*C:
\DOicruMentsandSctlinr3\AdB.i.ni.3rtrator\Debu£M£'J^^F215.exe-
如
z5--Fc-■-■ei豊单钳J•■.-LEJ0SL0
5
2
Bl
药品馆售虽药品伯售鬲爲
L&0
如0式Du七了s5:
<*1:
A:
1虽編总聶AS-JA生snfflsH™靈農1A入IAIA淸睛请请
FJ药針药入入入人诵请谊th
館害迂科E序
量额品品品品品系帙反|^恨安豆鼻、>>A>.1231bR
输入药品的信息
Z'.MHHWPM
EHC百•■MVt
疲F兄国民
理昭
■口2则■瞰BrMHhdhrrvthffkMlMPfHIMIVCfd
更Hr一
*口-
fl
•itylr"至品虽蚩-sn_
茹封I吗皤萨品#售前
ISITM|rl!
iMHiHtl
14*14AR_MNliAi
44J3Bmw*w
$学单A£fi_4xI..F-车.",f-±ttsieL7«ykJ*-?
按药品的编号
"C±^frC!
ijL>«iLt^^aiLSettmgs^AiiiLUiJ.2itLalo£\Debu.gM^l^flf:
21lB,exe
」匸国
蓼抒射生至可昌稍售锁«6那眞000酣O
2S12SQtw i^eainMTtnt*«h 审 勺 一義住! : 書 ■■■<一—亠託壬昂乩弔匸€•tNL..tM..H_*甲里 El^^^Ks” 君Elu r: u_范笑即加上r¥彌障毋录 I.81.H1S- 昱潮一案.•星畧金一寻吕71-吉亠系一#甘#菱壯上一T-主rt.pfe_.iyy->>iF2J4lnel 也fl cED 押rgswAE rwl &.翩Ibal称ffl 按药品的名称 SetIifLgsXkd^.uu=itlitui\Debug,R*r219.eze 166 IS 6& 按药品的销售额。 五、课设总结 六、附录(源代码) #include #include #include #definemaxsize100// 该医药公司药品最大种类 typedefstructnode//药品信息的存储结构类型定义 { charnum[10];//药品编号 charname[30]; floatprice;//单价 intcount;//销售量 floatsale;//销售额 }DataType; typedefstruct//存储药品信息的顺序表的定义 { DataTyper[maxsize]; intlength; inttype; }SqList; 按药品编号排序 voidnumber(SqList*L)// { inti,j; charnum1[10],name1[30]; for(j=i+1;j {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"); printf("\t药品编号药品名称药品单价 销售额\n"); for(i=0;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); } 判断两个 药品销售量药品 voidnam(SqList*L)//按药品名称排序{ inti,j; charnum1[10],name1[30]; for(i=0;i for(j=i+1;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; 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;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); voidpric(SqList*L)//按药品单价排序{ intcount1; for(j=i+1;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(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"); 药品 printf("\t药品编号药品名称药品单价药品销售量销售额\n"); for(i=0;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); voidcoun(SqList*L)//按药品销售量排序 { inti=0,j; charnum1[10],name1[30]; floatprice1,sale1; intcount1; for(j=i+1;j if(L->r[j].count>L->r[i].count) {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"); 药品 printf("\t药品编号药品名称药品单价药品销售量 销售额\n"); for(i=0;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); } voidsales(SqList*L)//按药品销售额排序 { inti=0,j; charnum1[10],name1[30]; floatprice1,sale1; intcount1; for(j=i+1;j 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"); printf("\t药品编号药品名称药品单价药品销售量药品 销售额\n"); for(i=0;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() { 销售记录排序\n"); printf("\t\t\t 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! error! \n");exit(0);}printf("请输入药品种类数(<=100): "); scanf("%d",&n);L->type=n;for(i=0;i printf("请输入该药品的编号(格式如: B125,前一位为大写字母, 后三位为数字): "); scanf("%s",num1);getchar(); printf("请输入该药品的名称: "); scanf("%s",name1);getchar(); printf("请输入该药品的单价: ");scanf("%f",&price1); printf("请输入该药品的销售量: ");scanf("%d",&count1);getchar();sale1=price1*count1;//销售额=单价*销售量 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! error! ");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;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; } } }
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 药店 药品 销售 统计 系统