热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

C语言实现医院管理系统

这篇文章主要为大家详细介绍了C语言实现医院管理系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下这个是C语言学完后的一个程序实践的内用。编写一个医院病人管理系统。这个程序有一些

这篇文章主要为大家详细介绍了C语言实现医院管理系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

 #include #include #include 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"[email protected]*码网); 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语言实现医院管理系统的详细内容,更多请关注gaodaima编程笔记其它相关文章!



推荐阅读
  • 本实验主要探讨了二叉排序树(BST)的基本操作,包括创建、查找和删除节点。通过具体实例和代码实现,详细介绍了如何使用递归和非递归方法进行关键字查找,并展示了删除特定节点后的树结构变化。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文详细介绍了C语言中链表的两种动态创建方法——头插法和尾插法,包括具体的实现代码和运行示例。通过这些内容,读者可以更好地理解和掌握链表的基本操作。 ... [详细]
  • 本文详细探讨了VxWorks操作系统中双向链表和环形缓冲区的实现原理及使用方法,通过具体示例代码加深理解。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 本文介绍如何使用Objective-C结合dispatch库进行并发编程,以提高素数计数任务的效率。通过对比纯C代码与引入并发机制后的代码,展示dispatch库的强大功能。 ... [详细]
  • 主要用了2个类来实现的,话不多说,直接看运行结果,然后在奉上源代码1.Index.javaimportjava.awt.Color;im ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • ImmutableX Poised to Pioneer Web3 Gaming Revolution
    ImmutableX is set to spearhead the evolution of Web3 gaming, with its innovative technologies and strategic partnerships driving significant advancements in the industry. ... [详细]
  • 本文探讨了 Objective-C 中的一些重要语法特性,包括 goto 语句、块(block)的使用、访问修饰符以及属性管理等。通过实例代码和详细解释,帮助开发者更好地理解和应用这些特性。 ... [详细]
  • 本文介绍了如何通过 Maven 依赖引入 SQLiteJDBC 和 HikariCP 包,从而在 Java 应用中高效地连接和操作 SQLite 数据库。文章提供了详细的代码示例,并解释了每个步骤的实现细节。 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 本文详细介绍了 MySQL 中 LAST_INSERT_ID() 函数的使用方法及其工作原理,包括如何获取最后一个插入记录的自增 ID、多行插入时的行为以及在不同客户端环境下的表现。 ... [详细]
  • Codeforces Round #566 (Div. 2) A~F个人题解
    Dashboard-CodeforcesRound#566(Div.2)-CodeforcesA.FillingShapes题意:给你一个的表格,你 ... [详细]
author-avatar
maylo1978
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有