C语言实现医院管理系统

 更新时间:2018年12月11日 15:42:27   作者:dk_zhe  
这篇文章主要为大家详细介绍了C语言实现医院管理系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

这个是C语言学完后的一个程序实践的内用。编写一个医院病人管理系统。这个程序有一些BUG,要操作得当,否则可能结果有问题。不过作为作业应付一下还是有模有样的。

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
typedef struct patient
{
 char ID[10];
 char name[10];
 char bingli[300];
 int cost[3];
 struct patient * next;
}node1;
typedef struct storage
{
 int amount[3];
 int price[3];
}node2;
node2 init(node2 temp)
{
 
 temp.amount[0]=20;
 temp.amount[1]=20;
 temp.amount[2]=10;
 temp.price[0]=5;
 temp.price[1]=9;
 temp.price[2]=16;
 return temp;
}
void mainmeun()
{
 printf("\n");
 printf(" 健康是快乐的源泉\n");
 printf("********************************\n");
 printf("1.注册新病人信息\n");
 printf("2.查询病人信息\n");
 printf("3.写病历\n");
 printf("4.病人消费\n");
 printf("5.列出所有病人信息\n");
 printf("6.载入所有病人信息\n");
 printf("7.保存\n");
 printf("8.查询药品库存\n");
 printf("9.离开\n");
 printf("*********************************\n");
}
node1 * create(node1 *p1)
{
 node1 *p;
 p=(node1 *)malloc(sizeof(node1));
 printf("请输入病人ID\n");
 scanf("%s",p->ID);
 
 while(p1->ID&&strcmp(p1->ID,p->ID))
 {
 p1=p1->next;
 }
 if(p1==NULL)
 {
 printf("请输入病人姓名\n");
 scanf("%s",p->name);
 strcpy(p->bingli,"0");
 p->cost[0]=0;
 p->cost[1]=0; 
 p->cost[2]=0;
 p->next=NULL;
 printf("已注入您的信息\n");
 return p;
 }
 else 
 {
 printf("输入病人ID以存在,注册失败\n");
 return p;
 }
}
node1 * insert(node1 * head,node1 *p)
{
 node1 *p1; 
 if(head==NULL)
 {
 head=p;
 p->next=NULL; 
 }
 else
 {
 p1=head;
 while(p1->next)
 {
 p1=p1->next; 
 }
 p1->next=p;
 p->next=NULL; 
 }
 return(head);
}
void search(node1 *p1)
{
 int sum;
 char a[10];
 printf("请输入病人ID\n");
 scanf("%s",a);
 while(p1->ID&&strcmp(p1->ID,a))
 {
 p1=p1->next;
 }
 if(p1)
 {
 printf("ID:%s\n",p1->ID);
 printf("姓名:%s\n",p1->name);
 printf("病例:%s\n",p1->bingli);
 printf("消费记录:\n");
 if(p1->cost[0])
 printf("巴米尔\t%d\n",p1->cost[0]);
 if(p1->cost[1])
 printf("感冒灵\t%d\n",p1->cost[1]);
 if(p1->cost[2])
 printf("病毒灵\t%d\n",p1->cost[2]);
 sum=p1->cost[0]*5+p1->cost[1]*9+p1->cost[2]*16;
 printf("总费用\t%d\n",sum);
 }
 else
 printf("该病人没有注册\n");
 
 
}
void bingli(node1 *p)
{
 char a[10];
 char bingli[300];
 char enter[5]=":\n";
 printf("请输入病人ID\n");
 scanf("%s",a);
 while(p->ID&&strcmp(p->ID,a))
 {
 p=p->next;
 }
 if(p==NULL)
 {
 printf("无该病人信息\n");
 }
 else
 {
 printf("请写病例:\n");
 scanf("%s",bingli);
 strcpy(p->bingli,bingli);
 strcat(p->bingli,enter);
 }
}
node2 buy(node1 *p,node2 temp)
{
 char i[10];
 printf("请输入病人ID\n");
 scanf("%s",i);
 while(p->ID&&strcmp(p->ID,i))
 {
 p=p->next;
 }
 
 while(1)
 {
 int a,b,c,d;
 printf("1.购买巴米尔\n");
 printf("2.购买感冒灵\n");
 printf("3.购买病毒灵\n");
 printf("0.退出\n");
 scanf("%d",&a);
 switch(a)
 {
 case 1:
 do
 {
 printf("现有库存%d\n",temp.amount[0]);
 printf("购买巴米尔数量:");
 scanf("%d",&b);
 temp.amount[0]=temp.amount[0]-b;
 p->cost[0]+=b*5; 
 }while(b>20);
 break;
 case 2:
 do
 {
 printf("现有库存%d\n",temp.amount[1]);
 printf("购买感冒灵数量:");
 scanf("%d",&c);
 temp.amount[1]=temp.amount[1]-c;
 p->cost[1]+=c*9;
 }while(c>20);
 break;
 case 3:
 do
 {
 printf("现有库存%d\n",temp.amount[2]);
 printf("购买病毒灵数量:");
 scanf("%d",&d);
 temp.amount[2]=temp.amount[2]-d;
 p->cost[2]+=d*16;
 }while(d>=10);
 break;
 case 0:
 return temp;
 }
 }
 
}
void list(node1 *p)
{
 
 if(p==NULL)
 printf("尚无病人信息\n");
 else
 { 
 do{
 printf("病人ID:%s\n",p->ID);
 printf("病人姓名:%s\n",p->name);
 
 printf("病人病例:%s\n",p->bingli);
 
 printf("购买巴米尔费用:%d\n",p->cost[0]);
 
 printf("购买感冒灵费用:%d\n",p->cost[1]);
 
 printf("购买病毒灵费用:%d\n",p->cost[2]);
 printf("\n");
 p=p->next; 
 }while(p!=NULL);
 }
}
node1 * load(node1 *p)
{ 
 char ID[10],name[10],bingli[300];
 int cost0,cost1,cost2;
 FILE *fp;
 fp=fopen("information.txt","r");
 int n=0;
 node1 *p1,*p2;
 
 while(!feof(fp))
 {
 n++;
 p1=(node1 *)malloc(sizeof(node1));
 fscanf(fp,"%s",ID);
 fscanf(fp,"%s",name);
 fscanf(fp,"%s",bingli);
 fscanf(fp,"%d",&cost0);
 fscanf(fp,"%d",&cost1);
 fscanf(fp,"%d",&cost2);
 
 strcpy(p1->ID,ID);
 strcpy(p1->name,name);
 strcpy(p1->bingli,bingli);
 p1->cost[0]=cost0;
 p1->cost[1]=cost1;
 p1->cost[2]=cost2;
 p1->next=NULL; 
 
 if(n==1)
 {
 p=p1;
 p2=p1;
 }
 
 else
 {
 p2->next=p1;
 p2=p1;
 
 }
 }
 
 fclose(fp);
 
 return p;
}
void save(node1 *p)
{
 FILE *fp;
 fp=fopen("information.txt","w");
 if(p!=NULL)
 do{
 fprintf(fp,"%s\n",p->ID);
 fprintf(fp,"%s\n",p->name);
 fprintf(fp,"%s\n",p->bingli);
 fprintf(fp,"%d\n",p->cost[0]);
 fprintf(fp,"%d\n",p->cost[1]);
 fprintf(fp,"%d\n",p->cost[2]);
 p=p->next;
 }while(p!=NULL);
 fclose(fp);
}
void liststock(node2 temp)
{
 printf("药品\t数量\t价格\t\n");
 printf("巴米尔\t%d\t%d\t\n",temp.amount[0],temp.price[0]);
 printf("感冒灵\t%d\t%d\t\n",temp.amount[1],temp.price[1]);
 printf("病毒灵\t%d\t%d\t\n",temp.amount[2],temp.price[2]);
 
}
chose()
{
 node1 *head=NULL,*p;
 node2 temp;
 temp=init(temp);
 while(1)
 {
 mainmeun();
 int a;
 scanf("%d",&a);
 switch(a)
 {
 case 1:
 p=create(head);
 head=insert(head,p);
 break;
 case 2:
 search(head);
 break;
 case 3:
 bingli(head);
 break;
 case 4:
 temp=buy(head,temp);
 break;
 case 5:
 list(head);
 break;
 case 6:
 head=load(head);
 break;
 case 7:
 save(head);
 break;
 case 8:
 liststock(temp);
 break;
 case 9:
 printf("谢谢使用\n");
 return(0);
 default:
 printf("输入有误,重新输入\n");
 break;
 }
 }
}
void main()
{
 chose();
}

运行时的截图,由于模块太多,就看看主页面吧。

更多学习资料请关注专题《管理系统开发》。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 深入解析C++中的虚函数与多态

    深入解析C++中的虚函数与多态

    对C++ 了解的人都应该知道虚函数(Virtual Function)是通过一张虚函数表(Virtual Table)和一个指向虚函数表的指针(vptr)来实现的
    2013-09-09
  • c语言多进程tcp服务器示例

    c语言多进程tcp服务器示例

    这篇文章主要介绍了c语言多进程tcp服务器示例,多进程socket,epoll实现IO复用,需要的朋友可以参考下
    2014-03-03
  • 漫画讲解C语言中最近公共祖先的三种类型

    漫画讲解C语言中最近公共祖先的三种类型

    这篇文章主要总结了使用C语言查找最近公共祖先的三种方法类型,用漫画的方式讲解原理定义,看上去更生动形象,帮助你更好的理解透彻,快来跟着本文往下看吧
    2021-11-11
  • QT实现用户登录注册功能

    QT实现用户登录注册功能

    这篇文章主要为大家详细介绍了QT实现用户登录注册功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06
  • 适合新手小白DEV C++的使用方法

    适合新手小白DEV C++的使用方法

    Dev-C++是一个Windows环境下C/C++的集成开发环境(IDE),它是一款自由软件,遵守GPL,下面这篇文章主要给大家介绍了关于适合新手小白DEV C++的使用方法,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-02-02
  • C语言双指针多方法旋转数组解题LeetCode

    C语言双指针多方法旋转数组解题LeetCode

    这篇文章主要为大家介绍了C语言双指针使用多方法旋转数组题解LeetCode,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2022-02-02
  • C++图论之Bellman-Ford算法和SPFA算法的实现

    C++图论之Bellman-Ford算法和SPFA算法的实现

    贝尔曼-福特算法(Bellman-Ford)是由理查德·贝尔曼和莱斯特·福特创立的,求解单源最短路径问题的一种算法。SPFA 算法是 Bellman-Ford算法 的队列优化算法的别称,通常用于求含负权边的单源最短路径。本文将详解两个算法的实现,需要的可以参考一下
    2022-06-06
  • OpenCV cv.Mat与.txt文件数据的读写操作

    OpenCV cv.Mat与.txt文件数据的读写操作

    这篇文章主要介绍了OpenCV cv.Mat 与 .txt 文件数据的读写操作,现在分享给大家,也给大家做个参考
    2018-05-05
  • C 语言中strstr函数实例详解

    C 语言中strstr函数实例详解

    这篇文章主要介绍了C 语言中strstr函数实例详解的相关资料,需要的朋友可以参考下
    2017-07-07
  • C++实现LeetCode(210.课程清单之二)

    C++实现LeetCode(210.课程清单之二)

    这篇文章主要介绍了C++实现LeetCode(210.课程清单之二),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08

最新评论