数学建模社区-数学中国
标题:
面试顺序问题:用数学建模优化生产与服务运作中的管理问题
[打印本页]
作者:
浅夏110
时间:
2020-6-16 14:57
标题:
面试顺序问题:用数学建模优化生产与服务运作中的管理问题
例题: 有 4 名同学到一家公司参加三个阶段的面试:公司要求每个同学都必须首先 找公司秘书初试,然后到部门主管处复试,最后到经理处参加面试,并且不允许插队(即 在任何一个阶段 4 名同学的顺序是一样的)。由于 4 名同学的专业背景不同,所以每人 在三个阶段的面试时间也不同,如表 5 所示。这 4 名同学约定他们全部面试完以后一起离开公司。假定现在时间是早晨 8:00,请问他们最早何时能离开公司?
3 X0 Q: f4 V3 V- |/ [
, d2 ?* c( X* S% q
( ~& [0 v0 x" C3 {, `
9 H1 R, R3 X3 n" I$ F% L+ Z
1 建立模型
+ c% `+ P# O2 z5 B; P$ B9 W9 K& B
实际上,这个问题就是要安排 4 名同学的面试顺序,使完成全部面试所花费的时 间最少。
4 ~1 v( ?8 R8 T3 P7 ?: g6 X
! Y1 d3 y9 M1 a: c
记
为第i名同学参加第 j 阶段面试需要的时间(已知),令
表示第i名同学参加第 j 阶段面试的开始时间(不妨记早上 8:00 面试开始为 0 时刻) (i=1,2,3,4 ; j =1,2,3),T 为完成全部面试所花费的最少时间。
& c$ Z7 `5 ~ d: ~# ^8 E7 P
: g/ m7 q4 K" O. e+ }
优化目标为
(1)
+ T7 r5 x0 B- I5 I/ y* b
5 E9 {- J+ w5 m$ H M( x% \+ [
约束条件:
; w* H2 \2 }9 C! T
4 H' v$ \$ S2 P* c) V/ H& M
1)时间先后次序约束(每人只有参加完前一个阶段的面试后才能进入下一个阶段):
(2)
4 L- ?3 d; b9 T$ Y
9 L9 t8 M+ w7 i6 n/ `0 p+ P
2 )每个阶段 j 同一时间只能面试 1 名同学:用 0− 1 变量 表示第k 名同学是否 排在第i名同学前面(1 表示“是”,0 表示“否”),则
/ r) L& P. k! t& B- o8 @! f3 r/ p
' K9 q& q4 b1 G. W! J+ U& n
(3)
8 O; ^& F6 N) c" c' V; X
. g/ e% K: A# Z* c- u
可以将上述非线性的优化目标(1) 改写为如下线性优化目标:
' P$ F) h' ]3 ^# v6 c- h5 }: M
3 j6 z" |; F& a; b6 x* M1 N
(4)
# I8 j; D0 t$ Q) ?: y- U" y8 b
8 _/ s2 R M# y9 g* T/ ^" {
式(2)~(4)就是这个问题的 0−1 非线性规划模型(当然所有变量还有非负约束,变量
还有 0− 1约束)。
4 | Y& b3 i* o2 p, n
, `. N9 B" E# Z+ v
2 求解模型
" u* T+ a3 W2 c. J- }8 e/ r
编写 LINGO 程序如下:
/ h0 I8 F, z+ Z4 b9 u4 ~8 W
7 d1 }; {4 A0 U( h X4 O. X. `
model:
. }7 e! W( u4 d; c. a7 [
Title 面试问题;
7 ~* z! f8 D U- a. k
SETS: Person/1..4/;
7 F/ D9 k/ m) `2 G; ?" J. O
Stage/1..3/;
& }# O5 _5 Z+ P( h; V( I! m
PXS(Person,Stage): T, X;
0 ~. d' j1 y8 J+ K, x7 Z
PXP(Person,Person)|&1 #LT# &2: Y;
0 E( z0 Y/ o+ a, G* X X" k
ENDSETS
: V" V8 w0 D' `8 w
DATA:
7 U% V: T C5 D& {/ ]
T=13, 15, 20, 10 , 20 , 18, 20, 16, 10, 8, 10, 15;
# j% M$ l' k' b2 D
ENDDATA
9 |4 o1 s: T% W a
[obj] min=MAXT;
0 H l. s) B$ h7 o- g9 k# [( I
MAXT>= @max(PXS(i,j)|j#EQ#@size(stage):x(i,j)+t(i,j));
" ]- t0 |! }& A- T- f, E
! 只有参加完前一个阶段的面试后才能进入下一个阶段;
& M8 k7 ~2 `2 ^ z8 ~+ r- M# B
@for(PXS(i,j)|j#LT#@size(stage):[ORDER]x(i,j)+t(i,j)<x(i,j+1));
9 T8 [1 a, Y; H' ?
! 同一时间只能面试1名同学;
, |8 O" D( c1 z0 W( _
@for(Stage(j):
4 ?7 i4 |7 J+ U$ _0 V8 y
@for(PXP(i,k):[SORT1]x(i,j)+t(i,j)-x(k,j)<MAXT*Y(i,k));
$ m8 v' y e2 q
@for(PXP(i,k):[SORT2]x(k,j)+t(k,j)-x(i,j)<MAXT*(1-Y(i,k))));
" u) O; g6 y4 G$ i. N- L
@for(PXP: @bin(y));
( U% @, [" x( J! N5 a! H& ?
end
5 L7 x/ h5 j& N U
计算结果为,所有面试完成至少需要 84min,面试顺序为 4-1-2-3(丁-甲- 乙-丙)。早上 8:00 面试开始,最早 9:24 面试可以全部结束。
5 q, A3 T, ^; k
————————————————
: \) C: ~; E6 ^1 m
版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
) Q2 v$ |4 Z K7 o
原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89387723
9 b/ H. N- \1 x# v, w9 S
( L% R S0 \, @, V, z- p, S* _$ Q
* G7 t5 l: I& a7 V( U* q9 p( } t
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5