访问【WRITE-BUG数字空间】_[内附完整源码和文档]
这道题的重点在于怎么处理患者的治疗过程。大二上学期的理论课上,我们在第一节的研讨课上对于这道题的实现进行了探讨。本题的患者排队与数据结构中的队列结构完全符合,当患者挂号后,检查该科室是否还有空闲的医生,若有,则直接进入进行治疗。若没有,则进入该科室的诊疗队列排队。每个科室的排队情况通过查询各个队列的长度即可得知。当时间刷新,有病人的医生诊疗时间发生变化,当变为 0 时,分配该病人 B 超时间。对于需要 B 超的患者,进入 B 超等候队列,依次进入各个 B 超室。
综合应用设计说明
某医院普通门诊拥有科室 15 个,每个科室值班医生 3 人;B 超室 1 个,有 3 台 B 超机。现需设计一个叫号系统,通过挂号次序,安排每个科室叫号顺序,各科室在诊断完病人后,根据其是否开具 B 超检查要求,安排 B 超室的叫号顺序,并在所有过程中,记录每位医生所看的病人及其听诊时间。
需实现挂号过程,医生就诊过程。
显示各科室、B超室目前排队情况。
查看各医生就诊的所有病人。
软件功能
病人选择科室进行挂号,自动分配患者编号
显示各个科室与 B 超室当前仍在排队等候的人数
显示每个医生(B 超室)当前病人还剩余的诊疗(检查)时间
显示当天已经过分钟数
根据医生编号查询当天医生诊疗病人的记录
根据时间刷新,自动分配患者到对应的医生(B 超室)进行治疗(检查)
将所有就诊记录存于文件,运行完程序可进行保存(对应于医院一天的营业结束)
查询就诊记录是通过数据文件读取比对实现的,当医生治疗一个病人的同时,对数据文件进行写入。病人挂号系统与自动分配诊室是通过建立病人的队列实现的,当时间刷新,每个诊室的情况都会重新更新,从而实现挂号、就诊、检查的过程。而各科室、B 超室的排队情况只需检查病人的排队队列长度即可获得。
设计思想
这道题的重点在于怎么处理患者的治疗过程。大二上学期的理论课上,我们在第一节的研讨课上对于这道题的实现进行了探讨。本题的患者排队与数据结构中的队列结构完全符合,当患者挂号后,检查该科室是否还有空闲的医生,若有,则直接进入进行治疗。若没有,则进入该科室的诊疗队列排队。每个科室的排队情况通过查询各个队列的长度即可得知。当时间刷新,有病人的医生诊疗时间发生变化,当变为 0 时,分配该病人 B 超时间。对于需要 B 超的患者,进入 B 超等候队列,依次进入各个 B 超室。同样的,时间刷新后 B 超室内患者检查时间变为 0 时,患者的治疗过程结束。B 超室会从 B 超的等候队列中寻找新的需要检查的患者。从现实中的排队联想到队列结构也是很正常的想法。
队列的元素为患者节点,节点本身有患者的各项信息,跟随患者类进行传输。每个科室(包括 B 超室)均有一条患者队列,代表等待队列。患者治疗情况的变化会引起患者节点的入队列与出队列。
而医生节点与 B 超室节点均需记录患者编号与剩余时间,而这两个节点的存储采用顺序表的结构(即数组)。
ui 界面中需要展示的部分,通过读取队列与医生数组、B 超室数组的数据即可解决。查询部分需要按行查询文件中的信息。