当前位置: 首页 > news >正文

数据结构——第三章 栈与队列(4)

队列的应用

  • 1.基于队列的医院挂号模拟系统
  • 2.队列的运用

1.基于队列的医院挂号模拟系统

代码实现分享

2.队列的运用

问题描述:某运动会设立N个比赛项目,每个运动成员可以参加1~3个项目。试问如何安排比赛日程,既可以使同一运动员参加的项目不安排在同一时间进行,又可以使总的竞赛项目日程最短。
若将此问题抽象成数学模型,则归属于“划分子集问题”,即将集合A划分成k个不想交的子集:A1,A2…,Ak(K<=n),使得同一子集中的元素均无冲突关系,并要求划分子集数目尽可能地少。
也可以把这个问题表述为:同一子集的项目为可以同时进行的项目,并且希望运动会的日程尽可能的短。
解决划分子集问题可利用“过筛”的方法。从第一个元素考虑起,凡不和第一个元素发生冲突的元素都可以和它分在同一子集中,然后再“过筛”出一批互补冲突的元素为第二子集,依此类推,直至所有元素都进入某个子集为止。

为了更好地描述用“过筛”的方法划分子集,用队列保存待选项目编号,用一维数组case保存待选项编号与已入选子集的项目编号的冲突情况。排在队头的项目编号i是当前的待选项目,能否入选由case[i]的值来决定,值为0表示与当前子集的项目无冲突,i出队并加入子集;反之则有冲突,i出队并重新排队,等待下一个子集的筛选。

下面给出划分第1个子集A1的主要步骤。
(1)将项目编号0~8依次进队列。将队头的项目编号0出队,放入子集A1中,将冲突数组与项目0对应的行取出放入一维数组case中。此时case中的每个元素的值表示元素下标的项目与项目0的冲突情况。
(2)当前队头是项目1,项目1能否加入子集A1由case[1]的值来决定。当前case[1]是1,表示项目1与子集A1中的项目0有冲突,项目1不能加入子集A1,出队后直接入队。
(3)当前队头是项目2,项目2能否加入子集A1由case[2]的值来决定。当前case[2]是0,表明项目2与子集A1中的已有项目没有冲突,项目2出队后加入子集A1。现在A1中已经有了2个项目,后来入选的项目必须与A1中的2个项目都没有冲突,为此将冲突表中与刚入选的项目2对应的行按下标与case数组相加,用两者的和更新case数组,此时的case数组是后续待选项目能否入选的依据。
(4)当前队头是项目3,项目3能否加入子集A1由case[3]的值来决定。当前case[3]是0,表明项目3与子集A1中的已有项目没有冲突,项目3出队后加入子集A1。现在A1中已经有3个项目,后来入选的项目必须与A1中的3个项目都没有冲突,为此将冲突表中与刚入选的项目3对应的行按小标与case数组相加,用两者的和更新case数组。此时的case数组是后续待选项目能否入选的依据。
(5)当前队头是项目4,项目4能否加入子集A1由case[4]的值来决定。当前case[4]是1,表明项目4与子集A1中的已有项目有冲突,项目不能加入子集A1,出队后直接进队。
(6)当前队头是项目5,项目5能否加入子集A1由case[5]的值来决定。当前case[5]是2,表明项目5与子集A1中的已有项目冲突,项目5不能加入子集A1,出队后直接入队。
(7)当前队头是项目6,项目6能否加入子集A1由case[6]的值来决定。当前是1,表明6与子集A1中的已有项目冲突,项目6不能加入子集A1,出队后直接入队。
(8)当前的队头是项目7,项目7能否加入子集A1由case[7]的值来决定。当前case[7]是0与子集A1中的已有项目没有冲突,项目7出队后放入子集A1。现在A1中已经有4个项目,后来的项目必须与A1中的4个项目都没有冲突,为此将冲突表中与刚入选的项目7对应的行按下标与case数组相加,用两者的和更新case数组,此时的case数组后续待选项能否入选的依据。
(9)当前队头是项目8,项目8能否加入子集A1由case[8]的值来决定。当前case[8]是1,表明项目8与子集A1中的已有项目有冲突,项目8不能加入子集A1,出队后直接入队。

当排在队头的项目编号小于刚加入子集的项目编号时,表示队列中的所有项目都被“过筛”一遍,第一个子集划分完成。用同样的方法划分其他子集,直到队列为空。

划分子集算法的基本思想如下。

pre = n;组号 = 0;//n为数据元素的个数
全体成员入栈
while(队列不能为空)
{ //队头元素i出队列;
if(i<pre)//开辟新的组
{
组号++;
case 数组初始化;
}
if(i能入组)//i与该组的元素没有冲突
{
i入组,记下序号为i的元素所属组号;
修改case数组;
}
else i重新入队列;
pre=i;//前一个出队列的元素序号
}

相关文章:

数据结构——第三章 栈与队列(4)

队列的应用1.基于队列的医院挂号模拟系统2.队列的运用1.基于队列的医院挂号模拟系统 代码实现分享 2.队列的运用 问题描述&#xff1a;某运动会设立N个比赛项目&#xff0c;每个运动成员可以参加1~3个项目。试问如何安排比赛日程&#xff0c;既可以使同一运动员参加的项目不…...

华为机试HJ73-计算日期到天数转换

HJ73 计算日期到天数转换 题目描述&#xff1a; 描述 根据输入的日期&#xff0c;计算是这一年的第几天。 保证年份为4位数且日期合法。 进阶&#xff1a;时间复杂度&#xff1a;O(n) &#xff0c;空间复杂度&#xff1a;O(1) 输入描述&#xff1a; 输入一行&#xff0c;每行…...

【阅读笔记】你不知道的JavaScript--this与对象2

目录this默认绑定隐式绑定隐式丢失显示绑定API 调用上下文new 绑定this 绑定优先级其余绑定例外对象字面量与对象属性描述符迭代器遍历this 默认绑定 默认绑定适配 独立函数调用 默认绑定 this 指向全局对象&#xff1b; 故直接调用函数&#xff0c;该函数内部的 this 即指向全…...

单板TVS接地不当造成辐射骚扰超标问题分析-EMC

【摘要】 某产品EMC辐射骚扰测试超标&#xff0c;通过近远场扫描配合定位分析&#xff0c;逐步找出骚扰源、传播路径&#xff0c;最终通过修改 PCB 走线切断传播路径解决此问题。 1 故障现象 某产品在进行 EMC 研发摸底测试时发现&#xff0c;整机辐射骚扰垂直方向测试超标&a…...

用Python Flask为女朋友做一个简单的网站(附可运行的源码)

&#x1f31f;所属专栏&#xff1a;献给榕榕&#x1f414;作者简介&#xff1a;rchjr——五带信管菜只因一枚&#x1f62e;前言&#xff1a;该专栏系为女友准备的&#xff0c;里面会不定时发一些讨好她的技术作品&#xff0c;感兴趣的小伙伴可以关注一下~&#x1f449;文章简介…...

vue3+rust个人博客建站日记5-所有界面

没有数据的前端&#xff0c;是没有灵魂的。明明标题是vue3 rust &#xff0c;但日记撰写至今&#xff0c;似乎只有第一篇提及了Rust&#xff0c;这可不行。是时候一股作气&#xff0c;完成大部分页面绘制工作了&#xff01; 最后再说一次&#xff0c;时间要加速了。 ——普奇神…...

青少年软件编程C++一级真题(202212)

1、输入一个整数x&#xff0c;输出这个整数加1后的值&#xff0c;即x1的值。 时间限制&#xff1a;1000 内存限制&#xff1a;65536 输入 一个整数x&#xff08;0 ≤ x ≤ 1000&#xff09;。 输出 按题目要求输出一个整数。 样例输入 9样例输出 10 #include<iost…...

【Spring】AOP底层原理(动态代理)-》 AOP概念及术语 -》 AOP实现

个人简介&#xff1a;Java领域新星创作者&#xff1b;阿里云技术博主、星级博主、专家博主&#xff1b;正在Java学习的路上摸爬滚打&#xff0c;记录学习的过程~ 个人主页&#xff1a;.29.的博客 学习社区&#xff1a;进去逛一逛~ AOP - 面向切面编程一、简述AOP二、AOP底层原理…...

Java8 新特性 之 lambda 表达 和 函数式接口

—— lambda 表达式 概念 lambda 表达式是一个匿名函数&#xff0c;可以把 lambda 表达式理解为是一段可以传递的代码。更简洁、更灵活&#xff0c;使 Java 的语言表达能力得到了提升lambda 表达式是作为接口的实现类的对象&#xff08;万事万物皆对象&#xff09; 使用语法…...

Netty服务端和客户端开发实例

一、Netty服务端开发在开始使用 Netty 开发 TimeServer 之前&#xff0c;先回顾一下使用 NIO 进行服务端开发的步骤。(1)创建ServerSocketChannel&#xff0c;配置它为非阻塞模式;(2)绑定监听&#xff0c;配置TCP 参数&#xff0c;例如 backlog 大小;(3)创建一个独立的I/O线程&…...

linux基本指令和权限

目录 一.shell命令以及运行原理 二.Linux常用指令 1. ls 指令 2. pwd命令 3.cd指令 4. touch指令 5.mkdir指令&#xff08;重要&#xff09; 6.rmdir指令 && rm 指令&#xff08;重要&#xff09; 7.man指令&#xff08;重要&#xff09; 8.cp指令&#xff08;重要&…...

滚蛋吧,正则表达式!

大家好&#xff0c;我是良许。 不知道大家有没有被正则表达式支配过的恐惧&#xff1f;看着一行火星文一样的表达式&#xff0c;虽然每一个字符都认识&#xff0c;但放在一起直接就让人蒙圈了~ 你是不是也有这样的操作&#xff0c;比如你需要使用「电子邮箱正则表达式」&…...

序列号和反序列化--java--Serializable接口--json序列化普通使用

序列化和反序列化序列化和反序列化作用为什么需要用途Serializable使用serialVersionUID不设置的后果什么时候修改Externalizable序列化的顺序json序列化序列化和反序列化 序列化&#xff1a;把对象转换为字节序列的过程称为对象的序列化。 反序列化:把字节序列恢复为对象的过…...

Java异步任务编排

多线程创建的五种方式&#xff1a; 继承Thread类实现runnable接口。实现Callable接口 FutureTask(可以拿到返回结果&#xff0c;阻塞式等待。)线程池创建。 ExcutorService service Excutors.newFixedThreadPool(10); service.excute(new Runnable01());另外一种创建线程池…...

Hive与HBase的区别及应用场景

当数据量达到一定量级的时候&#xff0c;存储和统计计算查询都会遇到问题&#xff0c;今天了解一下Hive和Hbase的区别和应用场景。 一、定义 Hive是基于Hadoop的一个数据仓库工具&#xff0c;可以将结构化的数据文件映射为一张数据库表&#xff0c;并提供简单的sql查询功能&am…...

C++之单例模式

目录 1. 请设计一个类&#xff0c;只能在堆上创建对象 2. 请设计一个类&#xff0c;只能在栈上创建对象 3.请设计一个类&#xff0c;不能被拷贝 C98 C11 4. 请设计一个类&#xff0c;不能被继承 C98 C11 5. 请设计一个类&#xff0c;只能创建一个对象(单例模式) 设计…...

Redis十大类型——Set与Zset常见操作

Redis十大类型——Set与Zset常见操作Set命令操作简列基本操作展示删除移动剪切集合运算Zset基本操作简列添加展示反转按分数取值获取分数值删除分数操作下标操作如果我们对Java有所了解&#xff0c;相信大家很容易就明白Set&#xff0c;在Redis中也一样&#xff0c;Set的value值…...

车载雷达实战之Firmware内存优化

内存&#xff08;Memory&#xff09;是计算机中最重要的部件之一&#xff0c;计算机运时的程序以及数据都依赖它进行存储。内存主要分为随机存储器&#xff08;RAM&#xff09;,只读存储器&#xff08;ROM&#xff09;以及高速缓存&#xff08;Cache&#xff09;。仅仅雷达的原…...

【剑指Offer】JZ14--剪绳子

剪绳子详解1.问题描述2.解题思路3.具体实现1.问题描述 2.解题思路 首先想到的思路&#xff1a;因为是求乘积的最大值&#xff0c;所以如果截取剩下的是1&#xff0c;那还是它本身就没有意义。从此出发&#xff0c;考虑绳子长度是2、3、4、5…通过穷举法来找规律。 值–》拆分–…...

raspberry pi播放音视频

文章目录目的QMediaPlayerGStreamerwhat is GStreamer体系框架优势omxplayerwhat is omxplayercommand Linekey bindings运行过程中错误ALSA目的 实现在树莓派下外接扬声器&#xff0c; 播放某段音频&#xff0c; 进行回音测试。 QMediaPlayer 首先我的安装是5.11版本。 优先…...

告别纯手工!用X-AnyLabeling的SAM2模型,5分钟搞定复杂目标分割标注

5分钟解锁X-AnyLabeling的SAM2黑科技&#xff1a;复杂目标分割标注效率提升指南 当面对医学影像中不规则肿瘤轮廓、遥感图像中的破碎地块边界&#xff0c;或是工业质检场景下的缺陷区域时&#xff0c;传统矩形框标注就像用粉笔画框测量云朵形状——既笨拙又低效。X-AnyLabelin…...

避开Arduino PID编程的3个常见坑:为什么你的控制总是不稳?

Arduino PID控制实战&#xff1a;避开3个致命陷阱实现精准调节 当你在深夜盯着反复震荡的电机转速曲线&#xff0c;或是加热棒温度始终无法稳定的数据时&#xff0c;是否怀疑过自己复制的PID代码有问题&#xff1f;这不是你的错觉——大多数Arduino PID控制问题都源于三个容易被…...

gallery应用商店优化:提升本地AI平台的发现率与下载量

gallery应用商店优化&#xff1a;提升本地AI平台的发现率与下载量 【免费下载链接】gallery A gallery that showcases on-device ML/GenAI use cases and allows people to try and use models locally. 项目地址: https://gitcode.com/GitHub_Trending/gallery44/gallery …...

【计算机视觉】Intel RealSense深度相机与OpenCV融合:从基础配置到实时交互应用

1. 深度相机与OpenCV的黄金组合 第一次接触Intel RealSense深度相机时&#xff0c;我被它同时获取RGB和深度数据的能力惊艳到了。这就像给普通摄像头装上了"立体视觉"&#xff0c;不仅能看见物体的颜色和形状&#xff0c;还能精确感知物体离相机有多远。而OpenCV作为…...

一键迁移方案:OpenClaw配置备份与Qwen3-4B模型快速恢复

一键迁移方案&#xff1a;OpenClaw配置备份与Qwen3-4B模型快速恢复 1. 为什么需要配置迁移方案 上周我的开发机突然硬盘故障&#xff0c;导致所有OpenClaw配置丢失。重新配置飞书通道、模型连接和技能库花了大半天时间。这次教训让我意识到&#xff1a;自动化工具的配置本身也…...

OpenClaw本地知识库构建:Qwen2.5-VL-7B处理扫描版PDF与图片资料

OpenClaw本地知识库构建&#xff1a;Qwen2.5-VL-7B处理扫描版PDF与图片资料 1. 为什么选择OpenClaw搭建个人知识管理系统 去年搬家时&#xff0c;我翻出了三大箱纸质资料——从学生时代的课堂笔记到工作后的技术手册&#xff0c;全都堆在角落积灰。这些资料里藏着不少珍贵内容…...

Jupyter notebook学习容易忘的点

数字数字计算符合常识选择run selected cell就能运行单个块字符串字符串也能计算转义字符\n 表示换行\t 表示tab\\ 表示\ 斜杠本身...

观察者同步才是物理学真正的基石:局部重叠如何自然衍生出全部现实架构

物理学三大支柱——量子理论、广义相对论、标准模型——各自以惊人的精度描述着世界&#xff0c;却始终无法拼成一张完整的图景。为什么必须是31维洛伦兹时空&#xff1f;为什么规范群偏偏是SU(3)SU(2)U(1)/Z₆&#xff1f;为什么粒子谱、质量层级、测量问题和量子引力兼容性始…...

蒙特卡洛方法与科学计算十大经典算法解析

1. 蒙特卡洛方法&#xff1a;从赌场到科学计算的跨界革命 1946年&#xff0c;三位天才科学家在洛斯阿拉莫斯实验室的咖啡时间里&#xff0c;可能不会想到他们正在创造一种将彻底改变科学计算的方法。蒙特卡洛方法的名字来源于摩纳哥著名的赌城&#xff0c;这暗示了其核心思想—…...

Go语言的gRPC服务开发

Go语言的gRPC服务开发 1. gRPC简介 gRPC是Google开发的高性能、开源的RPC框架&#xff0c;基于HTTP/2协议和Protocol Buffers序列化格式。它支持多种语言&#xff0c;包括Go、Java、C、Python等&#xff0c;非常适合构建微服务架构。 gRPC的优势 高性能&#xff1a;基于HTTP/2协…...