数学建模社区-数学中国
标题:
面试顺序问题:用数学建模优化生产与服务运作中的管理问题
[打印本页]
作者:
浅夏110
时间:
2020-6-16 14:57
标题:
面试顺序问题:用数学建模优化生产与服务运作中的管理问题
例题: 有 4 名同学到一家公司参加三个阶段的面试:公司要求每个同学都必须首先 找公司秘书初试,然后到部门主管处复试,最后到经理处参加面试,并且不允许插队(即 在任何一个阶段 4 名同学的顺序是一样的)。由于 4 名同学的专业背景不同,所以每人 在三个阶段的面试时间也不同,如表 5 所示。这 4 名同学约定他们全部面试完以后一起离开公司。假定现在时间是早晨 8:00,请问他们最早何时能离开公司?
3 \# ]" A4 d, H7 t) B
* n& `/ ^# F9 V' T
5 ~* W( A1 s4 @' O% Z9 ]
3 g6 w/ I x$ ~6 T- u( o/ V. u
1 建立模型
7 _0 u5 B# _& e. I/ c" ?( }6 G
实际上,这个问题就是要安排 4 名同学的面试顺序,使完成全部面试所花费的时 间最少。
G- q" S/ V) A7 K+ A" P- o# e6 T
9 B# G+ _" a8 g; A
记
为第i名同学参加第 j 阶段面试需要的时间(已知),令
表示第i名同学参加第 j 阶段面试的开始时间(不妨记早上 8:00 面试开始为 0 时刻) (i=1,2,3,4 ; j =1,2,3),T 为完成全部面试所花费的最少时间。
% f+ D8 L4 ?5 _5 v; q1 S
! V, L4 `1 X: E% p3 x# w& r: C
优化目标为
(1)
4 c) ?; X' o. n8 a5 `3 h
% ^) }3 U' o$ Q3 C3 x
约束条件:
+ T" u l% L- d4 Y( Y2 ^; i! p# B2 C* ]9 L
3 `7 k" e/ I$ O( `7 ~# d6 f
1)时间先后次序约束(每人只有参加完前一个阶段的面试后才能进入下一个阶段):
(2)
8 X$ P2 [6 M: K* }7 [' W; c
' w2 F G- D+ z, F: t; }7 D& S! P
2 )每个阶段 j 同一时间只能面试 1 名同学:用 0− 1 变量 表示第k 名同学是否 排在第i名同学前面(1 表示“是”,0 表示“否”),则
8 ~) n, E6 x- Z0 M$ a
& `- d$ F5 t$ e3 x4 _' f- ~+ ^
(3)
, T1 F1 |7 S# e. K: |
1 y* `9 l- W3 f0 X" V! A F
可以将上述非线性的优化目标(1) 改写为如下线性优化目标:
8 a) X& e5 p6 _
, @* m9 E) {* u
(4)
' [! A% A+ V& G4 K9 k
* _) L! t$ f, A. \8 u. z* r8 b' O
式(2)~(4)就是这个问题的 0−1 非线性规划模型(当然所有变量还有非负约束,变量
还有 0− 1约束)。
8 L# X: @- F4 Y$ P
[) w& A5 @- o: y$ g+ ^, [$ `( e5 p2 d* ]
2 求解模型
/ a I3 E8 _" x# r/ p6 ^( s
编写 LINGO 程序如下:
! a. j& o$ I! `0 P3 a
# e) b; ]3 `+ {" L
model:
6 u/ ^" C: P! b, x9 r T
Title 面试问题;
( I& g l W& v6 Q: x1 J4 C# w
SETS: Person/1..4/;
3 [& I$ ?' X/ b4 r
Stage/1..3/;
% n2 T$ l E- x- G- k( o
PXS(Person,Stage): T, X;
" {9 g; ^- b# e) Z$ s, s7 w+ [
PXP(Person,Person)|&1 #LT# &2: Y;
& | D. _$ I+ {9 z$ Q: C- L
ENDSETS
& p, `- \' x9 ]4 t
DATA:
$ X2 n" {2 ?3 ?& g) J) ~ L
T=13, 15, 20, 10 , 20 , 18, 20, 16, 10, 8, 10, 15;
; Z& i4 ]+ B, n% J
ENDDATA
* O/ t+ u+ ]4 v4 e7 H5 e/ J4 l
[obj] min=MAXT;
) r) l$ w% ?3 f V& ~% f C0 c5 X1 F
MAXT>= @max(PXS(i,j)|j#EQ#@size(stage):x(i,j)+t(i,j));
+ q% T3 M/ Y7 p, V# B. h4 |. {/ T+ ~
! 只有参加完前一个阶段的面试后才能进入下一个阶段;
|# X& D% [& q! j
@for(PXS(i,j)|j#LT#@size(stage):[ORDER]x(i,j)+t(i,j)<x(i,j+1));
3 V5 I% I9 N1 @8 t6 u
! 同一时间只能面试1名同学;
2 {' ]; [+ Q9 v0 A
@for(Stage(j):
. k( a2 K. y, R' M- o- X" x
@for(PXP(i,k):[SORT1]x(i,j)+t(i,j)-x(k,j)<MAXT*Y(i,k));
`+ z- I) l( u: R% [% b
@for(PXP(i,k):[SORT2]x(k,j)+t(k,j)-x(i,j)<MAXT*(1-Y(i,k))));
5 g4 q# F' G% J1 U* @3 x
@for(PXP: @bin(y));
3 u# i2 B+ @! L* Q. g
end
& j0 T2 b/ S$ Y8 y D" k- q& F% z
计算结果为,所有面试完成至少需要 84min,面试顺序为 4-1-2-3(丁-甲- 乙-丙)。早上 8:00 面试开始,最早 9:24 面试可以全部结束。
M0 f3 [! g' x4 V; b, D. V
————————————————
* S" e9 [" d! n! t7 n4 H
版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
/ N: X% Y& c3 g: M6 {# L
原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89387723
# s& x5 p) f' s* ^9 ~$ B. t) A
6 k4 P+ h. k" a; r
" d9 t9 ]& V+ J+ l
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5