c语言 标志位 周一到周五上班,运筹学整数规划求解这道题 鞍山街邮局从周一到周日所需值班人员如下表所示:周一 周二 周三 周四 周五 周六 周日 所需值班人数 15 17 14 14 15 19 20...

附件是用excel求解的结果,结果不唯一,但是最优值是39且唯一.

假设职工休息第i和j天的人数为xij,可知一共有10种.以此为变量编程,我用的mathematica:

data = {15, 17, 14, 14, 15, 19, 20};

x = Map[ToExpression["x" <> ToString@#] &,

Table[10 i + j, {i, 1, 5}, {j, 6, 7}], {2}];

vars = Flatten@x;

obj = Total@Total@x[[All, All]];

con0 = # >= 0 & /@ vars;

con1 = Table[obj - Total@x[[i, All]] >= data[[i]], {i, 1, 5}];

con2 = Table[obj - Total@x[[All, j - 5]] >= data[[j]], {j, 6, 7}];

cons = Join[con0, con1, con2];

Minimize[obj, cons, vars, Integers]

结果为:

{39, {x16 -> 12, x17 -> 2, x26 -> 1, x27 -> 2, x36 -> 3, x37 -> 2,

x46 -> 0, x47 -> 13, x56 -> 4, x57 -> 0}}

注意整数规划的结果唯一,但变量的取值通常不唯一.

第二个问类似,今天没时间做了...

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值