转载请注明出处。无形忍者:运筹优化实战案例-最优化员工排班
下图分别为员工信息(包含每日最短工作时长、最长工作时长、单位小时工作薪资、可工作时间)、每小时最短工作人数,要求满足以下条件:
请给出一种分配方案,使得每日支付员工的薪水最少。
员工姓名
最小工作小时
最大工作小时
每小时工资
可用性
王小明
6
8
30
6-20
李婷婷
6
8
50
张伟华
6
8
30
刘晓红
6
8
30
陈建国
6
8
40
杨丽丽
6
8
50
黄强强
6
8
45
6-18
赵静静
6
8
30
周文华
6
8
35
吴小刚
2
8
40
孙雅雅
2
3
60
0-6, 18-24
胡明明
2
4
40
朱强强
2
4
60
8-16
曾丽丽
2
6
55
许鹏飞
2
6
45
马晓霞
2
3
40
郑伟伟
2
5
50
12-24
谢娟娟
2
4
50
彭军军
2
4
40
方美丽
2
5
50
每个时段需要的最少员工数:

参数:

决策变量:创建20*24*24个变量
,表示员工在时间到时间是否工作注意:表示员工在工作,如果,则会造成在无人工作xd,i,jbinary,表示员工d在时间i到时间j是否工作0≤i≤231≤j≤24注意:i=6,j=9表示员工在6:00−9:00工作,如果maxj=23,则会造成在23:00−24:00无人工作\begin{matrix}{{x}_{d,i,j}}\quad binary,表示员工d在时间i到时间j是否工作\0\le i\le 23\1\le j\le 24\注意:i=6,j=9表示员工在6:00-9:00工作,如果maxj=23\,则会造成在23:00-24:00无人工作\end{matrix}
目标函数和约束:
目标函数:约束 目标函数: min∑d∈D∑i=023∑j>i24(j−i)∗xd,i,j∗cd 约束: ∑i=023∑j>i24xd,i,j≤∑i=startdi= end d∑j>ij= end d&mind≤j−i≤ max dxd,i,j≤1,∀d∈D∑d∈D∑i=023∑j>i&i≤c<j24xd,i,j≥Rc,∀c∈C\begin{array}{l} \text { 目标函数: } \ \min \sum_{d \in D} \sum_{i=0}^{23} \sum_{j>i}^{24}(j-i) x_{d, i, j} c_{d} \ \text { 约束: } \ \sum_{i=0}^{23} \sum_{j>i}^{24} x_{d, i, j} \leq \sum_{i={ start }_{d}}^{i=\text { end }_{d}} \sum_{j>i}^ {j=\text { end }_{d} \& \min _{d} \leq j-i \leq \text { max }_{d}} x_{d, i, j} \leq 1, \forall d \in D \ \sum_{d \in D} \sum_{i=0}^{23} \sum_{j>i \& i \leq c<j}^{24} x_{d, i, j} \geq R_{c}, \forall c \in C \ \end{array}
目标函数与约束说明:
目标函数:使得每日支付员工的薪水最少
约束1:如果员工d进行工作,则需满足个人工作时长不低于最小值、不高于最大值每位员工每天至多工作一个班次,每个班次都是一段连续的时间,员工 d 只工作一个班次,即至多只有一组 (i,j) 使得 xd,i,j x_{d, i, j} ≠0 ,从员工可开始工作时间开始扫描,在大于员工最少上班时间、小于最长上班时间内搜索,到员工必须结束工作时间为止,至多有一个状态变量为1
约束2:满足每小时最少工作人数
from ortools.sat.python import cp_model
# Define the problem 员工排班是一个整数规划问题
model = cp_model.CpModel()
EMPLOYEE = ["王小明", "李婷婷", "张伟华", "刘晓红", "陈建国", "杨丽丽", "黄强强", "赵静静",
"周文华", "吴小刚", "孙雅雅", "胡明明", "朱强强", "曾丽丽", "许鹏飞", "马晓霞",
"郑伟伟", "谢娟娟", "彭军军", "方美丽"]
MIN, MAX, COST, START, END = (
[6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2], # 最小工作小时数
[8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 3, 4, 4, 6, 6, 3, 5, 4, 4, 5], # 最大工作小时数
[30, 50, 30, 30, 40, 50, 45, 30, 35, 40, 60, 40, 60, 55, 45, 40, 50, 50, 40, 50], # 每小时薪资
[6, 0, 0, 0, 0, 0, 6, 0, 0, 0, 0, 0, 8, 0, 0, 0, 12, 0, 0, 0], # 可工作时段开始时间
[20, 24, 24, 24, 24, 24, 18, 24, 24, 24, 6, 24, 16, 24, 24, 24, 24, 24, 24, 24]) # 可工作时段结束时间
REQUIRED = [1, 1, 2, 3, 6, 6, 7, 8, 9, 8, 8, 8, 7, 6, 6, 5, 5, 4, 4, 3, 2, 2, 2, 2] # 每个时段需要的最少员工数
# 创建变量
x = {}
for d in EMPLOYEE:
for i in range(24):
for j in range(1, 25):
x[d, i, j] = model.NewBoolVar('')
# 创建目标函数
cost = sum((j - i) * x[d, i, j] * COST[EMPLOYEE.index(d)]
for d in EMPLOYEE
for i in range(24)
for j in range(i + 1, 25))
model.Minimize(cost)
# ....以上为部分代码最优解:4670.0
状态:OPTIMAL
求解时间:0.2649239秒
x[d,i,j]变量的取值:
(王小明, 8, 16) = 1
(李婷婷, 3, 11) = 1
(张伟华, 4, 12) = 1
(刘晓红, 8, 16) = 1
(陈建国, 16, 24) = 1
(杨丽丽, 12, 20) = 1
(黄强强, 9, 17) = 1
(赵静静, 4, 12) = 1
(周文华, 0, 8) = 1
(吴小刚, 16, 24) = 1
(胡明明, 10, 14) = 1
(曾丽丽, 11, 15) = 1
(许鹏飞, 7, 13) = 1
(马晓霞, 2, 5) = 1
(郑伟伟, 14, 19) = 1
(谢娟娟, 5, 9) = 1
(彭军军, 6, 10) = 1
(方美丽, 4, 9) = 1

配套视频链接:
原网址: 访问
创建于: 2025-12-21 21:51:59
目录: default
标签: 无
未标明原创文章均为采集,版权归作者所有,转载无需和我联系,请注明原出处,南摩阿彌陀佛,知识,不只知道,要得到
java windows火焰图_mob64ca12ec8020的技术博客_51CTO博客 - 在windows下不可行,不知道作者是怎样搞的 监听SpringBoot 服务启动成功事件并打印信息_监听springboot启动完毕-CSDN博客 SpringBoot中就绪探针和存活探针_management.endpoint.health.probes.enabled-CSDN博客 u2u转换板 - 嘉立创EDA开源硬件平台 Spring Boot 项目的轻量级 HTTP 客户端 retrofit 框架,快来试试它!_Java精选-CSDN博客 手把手教你打造一套最牛的知识笔记管理系统! - 知乎 - 想法有重合-理论可参考 安宇雨 闲鱼 机械键盘 客制化 开贴记录 文本 linux 使用find命令查找包含某字符串的文件_beijihukk的博客-CSDN博客_find 查找字符串 ---- mac 也适用 安宇雨 打字音 记录集合 B站 bilibili 自行搭建 开坑 真正的客制化 安宇雨 黑苹果开坑 查找工具包maven pom 引用地 工具网站 Dantelis 介绍的玩轴入坑攻略 --- 关于轴的一些说法 --- 非官方 ---- 心得而已 --- 长期开坑更新 [本人问题][新开坑位]关于自动化测试的工具与平台应用 机械键盘 开团 网站记录 -- 能做一个收集的程序就好了 不过现在没时间 -- 信息大多是在群里发的 - 你要让垃圾佬 都去一个地方看难度也是很大的 精神支柱 [超级前台]sprinbboot maven superdesk-app 记录 [信息有用] [环境准备] [基本完成] [sebp/elk] 给已创建的Docker容器增加新的端口映射 - qq_30599553的博客 - CSDN博客 [正在研究] Elasticsearch, Logstash, Kibana (ELK) Docker image documentation elasticsearch centos 安装记录 及 启动手记 正式服务器 39 elasticsearch 问题合集 不断更新 6.1.1 | 6.5.1 两个版本 博客程序 - 测试 - bug记录 等等问题 laravel的启动过程解析 - lpfuture - 博客园 OAuth2 Server PHP 用 Laravel 搭建带 OAuth2 验证的 RESTful 服务 | Laravel China 社区 - 高品质的 Laravel 和 PHP 开发者社区 利用Laravel 搭建oauth2 API接口 附 Unauthenticated 解决办法 - 煮茶的博客 - SegmentFault 思否 使用 OAuth2-Server-php 搭建 OAuth2 Server - 午时的海 - 博客园 基于PHP构建OAuth 2.0 服务端 认证平台 - Endv - 博客园 Laravel 的 Artisan 命令行工具 Laravel 的文件系统和云存储功能集成 浅谈Chromium中的设计模式--终--Observer模式 浅谈Chromium中的设计模式--二--pre/post和Delegate模式 浅谈Chromium中的设计模式--一--Chromium中模块分层和进程模型 DeepMind 4 Hacking Yourself README.md update 20211011
Laravel China 简书 知乎 博客园 CSDN博客 开源中国 Go Further Ryan是菜鸟 | LNMP技术栈笔记 云栖社区-阿里云 Netflix技术博客 Techie Delight Linkedin技术博客 Dropbox技术博客 Facebook技术博客 淘宝中间件团队 美团技术博客 360技术博客 古巷博客 - 一个专注于分享的不正常博客 软件测试知识传播 - 测试窝 有赞技术团队 阮一峰 语雀 静觅丨崔庆才的个人博客 软件测试从业者综合能力提升 - isTester IBM Java 开发 使用开放 Java 生态系统开发现代应用程序 pengdai 一个强大的博主 HTML5资源教程 | 分享HTML5开发资源和开发教程 蘑菇博客 - 专注于技术分享的博客平台 个人博客-leapMie 流星007 CSDN博客 - 舍其小伙伴 稀土掘金 Go 技术论坛 | Golang / Go 语言中国知识社区
最新评论