QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2782|回复: 0
打印 上一主题 下一主题

[建模教程] 面试顺序问题:用数学建模优化生产与服务运作中的管理问题

[复制链接]
字体大小: 正常 放大
浅夏110 实名认证       

542

主题

15

听众

1万

积分

  • TA的每日心情
    开心
    2020-11-14 17:15
  • 签到天数: 74 天

    [LV.6]常住居民II

    邮箱绑定达人

    群组2019美赛冲刺课程

    群组站长地区赛培训

    群组2019考研数学 桃子老师

    群组2018教师培训(呼伦贝

    群组2019考研数学 站长系列

    跳转到指定楼层
    1#
    发表于 2020-6-16 14:57 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta |邮箱已经成功绑定
    例题: 有 4 名同学到一家公司参加三个阶段的面试:公司要求每个同学都必须首先 找公司秘书初试,然后到部门主管处复试,最后到经理处参加面试,并且不允许插队(即 在任何一个阶段 4 名同学的顺序是一样的)。由于 4 名同学的专业背景不同,所以每人 在三个阶段的面试时间也不同,如表 5 所示。这 4 名同学约定他们全部面试完以后一起离开公司。假定现在时间是早晨 8:00,请问他们最早何时能离开公司?- M3 W1 e: r8 m6 H7 P+ L( B( H
    7 f/ g' F1 |4 G( c
    . B0 u3 R9 @/ ]( z0 k

    & w- B. w  z% E7 x8 D' X4 q$ C 1 建立模型
    5 V( T* H& A6 B0 j7 w9 }3 v   实际上,这个问题就是要安排 4 名同学的面试顺序,使完成全部面试所花费的时 间最少。
    % ^* p; a8 m5 K* n% b
    3 e) e1 ]( S( s/ C  为第i名同学参加第 j 阶段面试需要的时间(已知),令   表示第i名同学参加第 j 阶段面试的开始时间(不妨记早上 8:00 面试开始为 0 时刻) (i=1,2,3,4 ; j =1,2,3),T 为完成全部面试所花费的最少时间。 : N) X! r& K! `4 m( r: k; N

    ( u+ l9 ?4 a! K) C6 k7 K+ C1 B 优化目标为                            (1)
    , k( p' t2 F7 B9 u
    ; b- I; [) T, r$ H# a约束条件:" L, ?4 w) q# {5 Y
    2 n& c8 Z% N6 @. y+ _% _
    1)时间先后次序约束(每人只有参加完前一个阶段的面试后才能进入下一个阶段):                                (2), G8 ~. W" a& k/ B
    6 E4 _( X; {6 U7 I2 M
    2 )每个阶段 j 同一时间只能面试 1 名同学:用  0− 1 变量  表示第k 名同学是否 排在第i名同学前面(1 表示“是”,0 表示“否”),则 8 Z) s5 u- r+ A1 t7 Q" L2 W- [

    * ^, \& i! O1 K9 p2 S4 ?    (3)
    ! y- r' J/ o- X; C2 S' T8 F
    1 t; X  _9 z5 t1 Z' B7 M可以将上述非线性的优化目标(1) 改写为如下线性优化目标:
    8 T* n1 b+ a# l5 _- L* v- D( ]3 ?( p/ L) M; T
                       (4)8 d1 u- S7 v3 o  y* {0 t

    ( g* E* h5 @7 q# a! W# {  r. p式(2)~(4)就是这个问题的  0−1  非线性规划模型(当然所有变量还有非负约束,变量   还有  0− 1约束)。
    2 i5 ^, u5 w, W# p
    2 W1 m& X. s6 s: l( d" \$ y2  求解模型 5 M. i" `3 u0 l: f
    编写 LINGO 程序如下:
    " u' h$ H" |) X4 _: f
    ; M* j4 Z/ m/ d2 P1 n5 v8 Y3 lmodel:& f# ?! L! {# o7 y& X
    Title 面试问题; , q% l! D! H$ R& c% @- g
    SETS: Person/1..4/; ( u- r6 `6 T' X$ y& j
    Stage/1..3/;
    0 q% Q: V7 v( t$ q& a& APXS(Person,Stage): T, X; " Y8 y! }4 P* `) f% K% W
    PXP(Person,Person)|&1 #LT# &2: Y;
    ) B) ]2 w: s* }" _ENDSETS 2 N/ ~: S' g6 F! {1 x1 y
    DATA:
    % O. i) ~: \" BT=13, 15, 20, 10 , 20 , 18, 20, 16, 10, 8, 10, 15; : a; F, a7 G9 M3 a( M: T
    ENDDATA
    ! I' G0 _1 m6 B[obj] min=MAXT; ( B/ k5 b: e. G
    MAXT>= @max(PXS(i,j)|j#EQ#@size(stage):x(i,j)+t(i,j));
    * h* a  b& U% F1 m! 只有参加完前一个阶段的面试后才能进入下一个阶段;
    5 ]: @, d( b* @& e% v@for(PXS(i,j)|j#LT#@size(stage):[ORDER]x(i,j)+t(i,j)<x(i,j+1)); # u: O- P4 R. i, S& R
    ! 同一时间只能面试1名同学; 0 R! C$ a5 u2 h7 U) H- Q; J- `
    @for(Stage(j):   + b; x3 o) Z# B8 R$ r. ?
        @for(PXP(i,k):[SORT1]x(i,j)+t(i,j)-x(k,j)<MAXT*Y(i,k));  $ Z2 b1 V* t) q! i& n8 Y$ T
        @for(PXP(i,k):[SORT2]x(k,j)+t(k,j)-x(i,j)<MAXT*(1-Y(i,k)))); ( h/ B+ t, J: i7 j
    @for(PXP: @bin(y));
      K( z7 R6 x( ~$ s6 ?- p/ nend ' k: S) {( \- {3 j0 E7 B
    计算结果为,所有面试完成至少需要 84min,面试顺序为 4-1-2-3(丁-甲- 乙-丙)。早上 8:00 面试开始,最早 9:24 面试可以全部结束。
    & w1 a  L) N/ d3 M& a9 f8 ~————————————————
    : r2 o* `7 r3 y  P, Z版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    ! m6 @4 [9 F1 F原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89387723
    ( l) w! c+ |. M  \( }" b9 g. g+ t2 X7 Y% p/ |1 E# u. r- {
    6 q2 C, f; D& z3 F; U* K( B: m6 J
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-4-16 09:17 , Processed in 0.399558 second(s), 53 queries .

    回顶部