python - 护士调度示例:最长工作时间限制
问题描述
我正在用 Python 实现一个护士调度问题,类似于Google OR-Tools上提供的示例。
但是,我想实施一个硬性约束,即每位护士每周最多只能工作 40 小时(每个班次的持续时间不同)。在示例的上下文中(在 python 中)如何实现这一点?
我的方法是创建一个单独的列表,在其中定义每个班次的长度(类型类似于shift_requests
示例中的)。然后,hours_worked
为每位护士运行一些计数器,并检查给定的轮班分配是否会导致计数器超过 40 小时。但我不知道如何实现“检查”部分,我什至不确定这是否是解决这个问题的最佳方法。
解决方案
感谢@Stradivari 提供此解决方案。
一种方法是将布尔变量的总和与分配的长度分别约束为每个护士的系数(常数):
for n in all_nurses:
model.Add(sum(shift_durations[d][s] * shifts[(n, d, s)] for d in all_days for s in all_shifts) <= 40)
推荐阅读
- javascript - Vue:如何使用下载标签将文件下载到浏览器
- gcc - 什么是使用 gcc 在 cmake 中应用多种消毒剂的好方法
- javascript - 无法从 Javascript 中的对象访问属性
- javascript - 试图理解函数构造
- node.js - 如何在集成测试中使用 Sinon 存根服务?
- c# - 过程需要更多时间在连续迭代中完成
- python - virtualenvwrapper 已安装但无法正常工作
- laravel - 如何更改导出的csv列的格式-laravel excel
- nestjs - Nest.js - 嵌套 cli 没有获取最新的文件更改
- c# - 在 ArrayList C# 中搜索