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

运筹学经典问题(一):指派问题

问题描述

N N N个任务,需要 N N N个人去完成,每个人完成不同工作的效率不同(或者资源、收益等等),需要怎么分配使得整体的效率最高(成本最低等等)呢?这就是经典的指派问题啦!

数学建模

我们首先做以下定义:
I I I: 人的集合;
J J J: 任务的集合;
c i j c_{ij} cij: 把任务 j j j分配给 i i i的成本;

x i j x_{ij} xij: 是否把任务 j j j分配给 i i i,0-1变量;

m i n ∑ i ∈ I ∑ j ∈ J x i j c i j s . t ∑ i ∈ I x i j = 1 , ∀ j ∈ J ∑ j ∈ J x i j = 1 , ∀ i ∈ I min \sum_{i \in I} \sum_{j \in J}x_{ij}c_{ij} \\ s.t \sum_{i \in I}x_{ij}=1, \forall j\in J\\ \sum_{j \in J}x_{ij}=1, \forall i\in I\\ miniIjJxijcijs.tiIxij=1,jJjJxij=1,iI

目标函数表示最小化成本,第一行约束表示每个任务只能分配给一个人,第二行约束表示每个人只能被分配一个任务。

整数最优解特性

即使把变量 x e x_{e} xe松弛成 0 ≤ x e ≤ 1 0 \leq x_e \leq1 0xe1,原问题变成线性规划,该问题仍然存在整数最优解。

模型求解

方式一:将模型直接扔给求解器(Gurobi、Cplex)等求解就可以啦!如果对求解运筹模型时如何选择求解器有疑问的小伙伴,可以参考我的文章如何选择合适的求解器;
后面再补充python实现的代码(todo)

方式二:对算法求解速度有更高要求的,可以通过匈牙利算法、Ford-Fulkerson算法(FFA)等求解。

http://www.lryc.cn/news/260155.html

相关文章:

  • 产品经理之如何编写竞品分析(医疗HIS系统管理详细案例模板)
  • 虚拟内存管理
  • ssh时怎么同时指定其端口号,以及scp文件到远程的指定端口
  • Redis过期淘汰策略
  • 微信小程序---自定义组件
  • CGAL的最优传输曲线重构
  • 使用Docker本地安装部署Draw.io绘图工具并实现远程访问协作办公
  • 流程图、泳道图的介绍和示例分享,以及自定义元件库的介绍
  • RabbitMq的详细使用
  • 软件设计师——软件工程(二)
  • 阿里云RDS MySQL 数据如何快速同步到 ClickHouse
  • HINet技术要点
  • IntelliJ IDEA2023学习教程
  • MATLAB基础应用精讲-【数模应用】神经网络(补充篇)
  • 洛谷题单【算法1-7】搜索
  • WordPress主题Lolimeow v8.0.1二次元风格支持erphpdown付费下载
  • WTN6xxx系列OTP语音芯片:智能语音解决方案的可靠之选
  • 腾讯云Elasticsearch Service产品体验
  • SQLE 3.0 部署实践
  • 爬虫的分类
  • 简说vue-router原理
  • 什么是 Spring 框架?
  • Vue2.x源码:new Vue()做了啥
  • iOS 借助DSYMTools工具定位到闪退的具体行数和方法名
  • 分布式解决方案与实战
  • GitHub入门介绍
  • IP与子网掩码之间的关系
  • 文档或书籍扫描为 PDF:ScanPapyrus Crack
  • Clickhouse RoaringBitmap
  • C语言第四十九弹----模拟使用strcpy函数