药店的药品销售统计系统(排序应用_药店药品销售统计系统

其他范文 时间:2020-02-27 22:51:24 收藏本文下载本文
【www.daodoc.com - 其他范文】

药店的药品销售统计系统(排序应用由刀豆文库小编整理,希望给你工作、学习、生活带来方便,猜你可能喜欢“药店药品销售统计系统”。

实验五 药店的药品销售统计系统(排序应用)

一、实验目的1.帮助读者复习C++语言程序设计中的知识。

2.对数据进行排序时,可采用多种排序方法,如直接插入排序、冒泡排序、快速排序,直接选择排序等方法的实现。

[需求分析]

设计一系统,实现医药公司定期对销售各药品的记录进行统计,可按药品的编号、单价、销售量或销售额做出排名。

二、实验内容和要求

[问题要求] 设计一系统,实现医药公司定期对销售各药品的记录进行统计,可按药品的编号、单价、销售量或销售额做出排名。[问题分析] 在本设计中,首先从数据文件中读出各药品的信息记录,存储在顺序表中。各药品的信息包括:药品编号、药名、药品单价、销出数量、销售额。药品编号共4位,采用字母和数字混合编号,如:125,前一位为大写字母,后三位为12 数字,按药品编号进行排序时,可采用基数排序法。对各药品的单价、销售量或销售额进行排序时,可采用多种排序方法,如直接插入排序、冒泡排序、快速排序,直接选择排序等方法。在本设计中,对单价的排序采用冒泡排序法,对销售量的排序采用快速排序法,对销售额的排序采用堆排序法。

三、算法设计

首先从txt文件中读取数据信息并保存,本次试验采用了5中排序方法。其中编号排序是按照基数排序,采用多关键字进行排序。基数排序是借助“分配”和“收集”两种操作对单逻辑关键字进行排序的一种内排序方法。对单价的排序采用了直接插入排序和冒泡排序,直接插入排序就是首先将第一个元素看成是一个有序的,然后第二个元素和第一个比较,若大于第一个则放在其后面否则放前面,依次直至最后一个。冒泡排序就是采用两个循环,即将第一个元素和第二个比较若第一个大于第二个则交换,否则不变,然后第二个和第三个比较,同上。第一趟可将最大的一个放在最后,依次可得排序。销售量是快速排序,快速排序就是首先设置一个关键字,然后让最后一个和其比较,直至找到一个比关键字小的,然后和其交换,接下来让第一个和其比较,直至找到一个比其大的,然后交换,在找到的位置分别做标记,依次执行即可。销售额使用的是堆排序,堆排序首先要建立一个完全二叉树的堆,其标准符合为父节点始终比子节点大。然后依次输出顶结点,然后在建立一个符合标准的堆重复操作即可。

四、调试分析及数据测试 输入药品

五、测试结果

测试结果符合程序写作要求 #include #include #include #define maxsize 100 //该医药公司药品最大种类 typedef struct node //药品信息的存储结构类型定义 {

}DataType;

typedef struct //存储药品信息的顺序表的定义 {

}SqList;

void number(SqList *L)

//按药品编号排序 {

int i,j;

char num1[10],name1[30];float price1,sale1;int count1;

DataType r[maxsize];int length;int type;

char num[10];//药品编号 char name[30];float price;//单价 int count;//销售量 float sale;//销售额

m)>0)

e);

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

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

if(strcmp(L->r[j].num,L->r[i].nu

{ 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].nam

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;

后:n“);

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按药品编号排序

printf(“t药品编号

药品名称

药品单价

药品销售量

药品销售额n”);

printf(“t %st %st %ft for(i=0;itype;i++)%dt %fn”,L->r[i].num,L->r[i].name,L->r[i].price,L->r[i].count,L->r[i].sale);}

void nam(SqList *L)

//按药品名称排序 {

ame)>0)

e);

int i,j;

char num1[10],name1[30];float price1,sale1;int count1;

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

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

if(strcmp(L->r[j].name,L->r[i].n

{ 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].nam

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

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

后:n“);

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按药品编号排序

printf(“t药品编号

药品名称

药品单价

药品销售量

药品销售额n”);

printf(“t %st %st %ft for(i=0;itype;i++)%dt %fn”,L->r[i].num,L->r[i].name,L->r[i].price,L->r[i].count,L->r[i].sale);}

void pric(SqList *L){

e);

int i=0,j;

char num1[10],name1[30];float price1,sale1;int count1;

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(name1,L->r[j].name);strcpy(L->r[j].name,L->r[i].nam

后:n“);

药品单价

药品销售量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按药品编号排序

printf(“t药品编号

药品名称 药品销售额n”);for(i=0;itype;i++)

printf(“t %st %st %ft

%dt %fn”,L->r[i].num,L->r[i].name,L->r[i].price,L->r[i].count,L->r[i].sale);}

void coun(SqList *L){

int i=0,j;

char num1[10],name1[30];float price1,sale1;int count1;

for(i=0;itype;i++)for(j=i+1;jtype;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);

e);

后:n“);

药品单价 药品销售量strcpy(name1,L->r[j].name);strcpy(L->r[j].name,L->r[i].nam

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按药品编号排序

printf(“t药品编号

药品名称药品销售额n”);

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

printf(“t %st %st %ft

%dt %fn”,L->r[i].num,L->r[i].name,L->r[i].price,L->r[i].count,L->r[i].sale);

}

void sales(SqList *L){

int i=0,j;

char num1[10],name1[30];float price1,sale1;int count1;

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);

e);

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].nam

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”);

printf(“t %st %st %ft for(i=0;itype;i++)%dt %fn”,L->r[i].num,L->r[i].name,L->r[i].price,L->r[i].count,L->r[i].sale);}

void menu(){

-----------------n“);

|n”);

|n“);

|n”);

printf(“t|

3)按药品单printf(”t|

2)按药品名printf(“t|

1)按药品编printf(”ttt销售记录排序n“);printf(”t------------------------------

售量

|n“);

售额

|n”);printf(“t|

4)按药品销

printf(”t|

5)按药品销

printf(“t|

0)退出系统

|n”);

-----------------n“);}

int main(){

st));

printf(”t------------------------------

printf(“

请选择”);

SqList *L;int n,i,m;

char num1[10],name1[30];float price1,sale1;int count1;FILE *fp;

L=(SqList*)malloc(sizeof(SqLi //创建文件

error!n“);exit(0);}(

fp=fopen(”medince.txt“,”w“);

if(!fp){printf(”Sorry!File open

printf(“请输入药品种类数

scanf(”%d“,&n);L->type=n;

for(i=0;i

{

printf(”请输入该药品的编号(格式如:B125,前一位为大写字母,后三位为数字):“);

称:”);

价:“);

scanf(”%f“,&price1);printf(”请输入该药品的销售 scanf(“%s”,name1);getchar();

printf(“请输入该药品的单 scanf(”%s“,num1);getchar();

printf(”请输入该药品的名量:“);getchar();

fprintf(fp,”%st%st%ft%dt%f sale1=price1*count1;scanf(“%d”,&count1);n“,num1,name1,price1,count1,sale1);

error!”);exit(0);}

fscanf(fp,“%st%st%ft%dt%ffor(i=0;i

fclose(fp);L->length=0;

fp=fopen(”medince.txt“,”r“);if(!fp){printf(”Sorry!File open }

printf(“n”);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“);

printf(”t %st %st %ft for(i=0;itype;i++)%dt %fn“,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){

case 1:number(L);break;case 2:nam(L);break;case 3:pric(L);break;case 4:coun(L);break;case 5:sales(L);break;

误!”);break;

}

case 0:exit(0);break;

default:printf("Sorry!输入有

} }

下载药店的药品销售统计系统(排序应用word格式文档
下载药店的药品销售统计系统(排序应用.doc
将本文档下载到自己电脑,方便修改和收藏。
点此处下载文档

文档为doc格式

    热门文章
      整站推荐
        点击下载本文