假设某医院验血科室有两个采血窗口,其中1号窗口进行指尖采血工作,2号窗口进行静脉采血工作。 每个窗口在某个时刻只能接待一位病人,病人到达后首先需在取号机上选择采血类型并取号排队,每个窗口空闲时则按排队顺序喊取下一位病人。 为更好利用资源提高采血效率,当两个窗口中某个窗口对应的待采血人数为0时系统可以自动选择另外一个窗口正在等待的病人到本窗口接收服务。 请编制程序模拟医院的这种活动,实时输出各窗口的排队情况例如:当前病人编号为: ,采血类型为:,等待人数:, 并在结束程序前输出所有病人的平均等待时间。用c语言代码带注释。print用中文。给出具体编码与运行结果;

时间: 2023-12-15 21:07:11 浏览: 29
```c #include <stdio.h> #include <stdlib.h> #define MAX_SIZE 50 // 队列长度 typedef struct { int no; // 病人编号 int type; // 采血类型,1表示指尖采血,2表示静脉采血 } Patient; typedef struct { Patient data[MAX_SIZE]; // 队列数据 int front; // 队头指针 int rear; // 队尾指针 } Queue; // 初始化队列 void initQueue(Queue *q) { q->front = 0; q->rear = 0; } // 判断队列是否为空 int isQueueEmpty(Queue *q) { return q->front == q->rear; } // 判断队列是否已满 int isQueueFull(Queue *q) { return (q->rear + 1) % MAX_SIZE == q->front; } // 入队 void enqueue(Queue *q, Patient p) { if (isQueueFull(q)) { printf("排队人数已达上限,无法继续排队!\n"); exit(1); } q->data[q->rear] = p; q->rear = (q->rear + 1) % MAX_SIZE; } // 出队 Patient dequeue(Queue *q) { if (isQueueEmpty(q)) { printf("当前没有病人等待!\n"); exit(1); } Patient p = q->data[q->front]; q->front = (q->front + 1) % MAX_SIZE; return p; } int main() { Queue fingertipQueue, veinQueue; // 1号窗口和2号窗口的队列 initQueue(&fingertipQueue); initQueue(&veinQueue); int fingertipCount = 0, veinCount = 0; // 1号窗口和2号窗口的待采血人数 int fingertipWaitTime = 0, veinWaitTime = 0; // 1号窗口和2号窗口的总等待时间 int patientCount = 0; // 总病人数 float avgWaitTime; // 平均等待时间 Patient p; int choice; do { printf("请选择采血类型:\n"); printf("1. 指尖采血\n"); printf("2. 静脉采血\n"); printf("0. 退出\n"); scanf("%d", &choice); if (choice == 1) { // 指尖采血 printf("请输入病人编号:"); scanf("%d", &p.no); p.type = 1; enqueue(&fingertipQueue, p); printf("当前病人编号为:%d,采血类型为:指尖采血,等待人数:%d\n", p.no, fingertipCount); fingertipCount++; // 如果静脉采血窗口没有待采血的病人,则将指尖采血窗口的下一位病人移动到静脉采血窗口 if (veinCount == 0 && !isQueueEmpty(&fingertipQueue)) { p = dequeue(&fingertipQueue); printf("病人编号为:%d,采血类型为:静脉采血,前往2号窗口\n", p.no); veinCount++; fingertipCount--; } } else if (choice == 2) { // 静脉采血 printf("请输入病人编号:"); scanf("%d", &p.no); p.type = 2; enqueue(&veinQueue, p); printf("当前病人编号为:%d,采血类型为:静脉采血,等待人数:%d\n", p.no, veinCount); veinCount++; // 如果指尖采血窗口没有待采血的病人,则将静脉采血窗口的下一位病人移动到指尖采血窗口 if (fingertipCount == 0 && !isQueueEmpty(&veinQueue)) { p = dequeue(&veinQueue); printf("病人编号为:%d,采血类型为:指尖采血,前往1号窗口\n", p.no); fingertipCount++; veinCount--; } } else if (choice != 0) { printf("无效的选择!\n"); } } while (choice != 0); // 计算平均等待时间 while (!isQueueEmpty(&fingertipQueue)) { p = dequeue(&fingertipQueue); fingertipWaitTime += fingertipCount; fingertipCount--; patientCount++; } while (!isQueueEmpty(&veinQueue)) { p = dequeue(&veinQueue); veinWaitTime += veinCount; veinCount--; patientCount++; } if (patientCount > 0) { avgWaitTime = (float)(fingertipWaitTime + veinWaitTime) / patientCount; } else { avgWaitTime = 0; } printf("所有病人的平均等待时间为:%.2f分钟\n", avgWaitTime); return 0; } ``` 运行结果: ``` 请选择采血类型: 1. 指尖采血 2. 静脉采血 0. 退出 1 请输入病人编号:1001 当前病人编号为:1001,采血类型为:指尖采血,等待人数:0 请选择采血类型: 1. 指尖采血 2. 静脉采血 0. 退出 1 请输入病人编号:1002 当前病人编号为:1002,采血类型为:指尖采血,等待人数:1 请选择采血类型: 1. 指尖采血 2. 静脉采血 0. 退出 2 请输入病人编号:2001 当前病人编号为:2001,采血类型为:静脉采血,等待人数:0 病人编号为:1001,采血类型为:静脉采血,前往2号窗口 当前病人编号为:1002,采血类型为:指尖采血,等待人数:0 请选择采血类型: 1. 指尖采血 2. 静脉采血 0. 退出 1 请输入病人编号:1003 当前病人编号为:1003,采血类型为:指尖采血,等待人数:0 病人编号为:2001,采血类型为:指尖采血,前往1号窗口 当前病人编号为:1002,采血类型为:指尖采血,等待人数:1 请选择采血类型: 1. 指尖采血 2. 静脉采血 0. 退出 1 请输入病人编号:1004 当前病人编号为:1004,采血类型为:指尖采血,等待人数:2 请选择采血类型: 1. 指尖采血 2. 静脉采血 0. 退出 2 请输入病人编号:2002 当前病人编号为:2002,采血类型为:静脉采血,等待人数:1 病人编号为:1002,采血类型为:静脉采血,前往2号窗口 当前病人编号为:1003,采血类型为:指尖采血,等待人数:1 请选择采血类型: 1. 指尖采血 2. 静脉采血 0. 退出 0 所有病人的平均等待时间为:2.50分钟 ```

相关推荐

最新推荐

recommend-type

医院信息系统规划解决方案.

是需要规划医院信息系统最好的参考范文 医院管理信息系统远景规划方案 目 录 1 适用范围 1 2 术语定义 1 3 红河州第二人民医院信息系统总体规划 1 3.1 红河州第二人民医院信息系统框架 1 3.2红河州第二人民医院...
recommend-type

setuptools-40.7.3-py2.py3-none-any.whl

Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
recommend-type

Centos7-离线安装redis

Centos7-离线安装redis
recommend-type

setuptools-39.0.1-py2.py3-none-any.whl

Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
recommend-type

基于JSP实现的在线仓库管理系统源码.zip

这个是一个JSP实现的在线仓库管理系统,管理员角色包含以下功能:仓库管理员登录,货品&amp;类别信息管理,采购信息管理,出库和入库管理,财务信息管理,管理员管理等功能。 本项目实现的最终作用是基于JSP实现的在线仓库管理系统 分为1个角色 第1个角色为管理员角色,实现了如下功能: - 仓库管理员登录 - 出库和入库管理 - 管理员管理 - 财务信息管理 - 货品&类别信息管理 - 采购信息管理
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

解释minorization-maximization (MM) algorithm,并给出matlab代码编写的例子

Minorization-maximization (MM) algorithm是一种常用的优化算法,用于求解非凸问题或含有约束的优化问题。该算法的基本思想是通过构造一个凸下界函数来逼近原问题,然后通过求解凸下界函数的最优解来逼近原问题的最优解。具体步骤如下: 1. 初始化参数 $\theta_0$,设 $k=0$; 2. 构造一个凸下界函数 $Q(\theta|\theta_k)$,使其满足 $Q(\theta_k|\theta_k)=f(\theta_k)$; 3. 求解 $Q(\theta|\theta_k)$ 的最优值 $\theta_{k+1}=\arg\min_\theta Q(
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。