QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2775|回复: 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,请问他们最早何时能离开公司?
    ' \. d, E2 V6 N" S) E/ o7 V" ]  ~& L. x2 m  u4 k; p4 u& ]6 @

    3 p5 p( u* V/ d+ i& k2 S% m% B! u' D0 W; O& h, o0 `! T
    1 建立模型 + O, p$ h) w3 a- |- x
       实际上,这个问题就是要安排 4 名同学的面试顺序,使完成全部面试所花费的时 间最少。
    " x5 l( H' U: G$ G9 h4 T1 T( M/ ]9 v2 C7 ~1 Q, x/ M
      为第i名同学参加第 j 阶段面试需要的时间(已知),令   表示第i名同学参加第 j 阶段面试的开始时间(不妨记早上 8:00 面试开始为 0 时刻) (i=1,2,3,4 ; j =1,2,3),T 为完成全部面试所花费的最少时间。
    : ^3 l/ w+ U! i* }2 X5 H7 y: h1 r& X- N4 a/ x0 t# h$ ?
    优化目标为                            (1)
    4 H! k# L  T0 s" n
    ! R" F: W, P" G约束条件:* y, [8 ]; Q- ^: G0 Z  \2 @+ S: G
    $ W# ~5 j& G: w+ M" \' Q
    1)时间先后次序约束(每人只有参加完前一个阶段的面试后才能进入下一个阶段):                                (2)
    # ^6 p+ H0 x+ p$ y6 V  A
    . R; X) p; a4 U6 [2 )每个阶段 j 同一时间只能面试 1 名同学:用  0− 1 变量  表示第k 名同学是否 排在第i名同学前面(1 表示“是”,0 表示“否”),则 5 L( p8 ~! N8 ^3 o
    2 S$ |3 ~5 H# T5 b* u% X5 X
        (3)
    ! y* R; s) y7 t) o
    " x0 e+ g4 D6 B4 f( B可以将上述非线性的优化目标(1) 改写为如下线性优化目标:( z& d8 I+ m1 G7 q) w
    . s$ B: V( W; h
                       (4)
    7 s! i" ?& _1 x
    & K2 N' e* x0 ~- w6 s7 m式(2)~(4)就是这个问题的  0−1  非线性规划模型(当然所有变量还有非负约束,变量   还有  0− 1约束)。 3 g2 n1 k6 o  e& k$ _
    - |9 k; x$ s7 o6 @$ _8 H9 u* f
    2  求解模型 " u: V6 `* G0 v* m+ }0 d) e
    编写 LINGO 程序如下:" O- K- ^0 _" i/ g6 g. [) R) J
    ) j, I* @, {1 \/ ]
    model:
    5 }! Q* C8 l9 \2 YTitle 面试问题; ! N+ I- I/ W/ O+ {
    SETS: Person/1..4/; 5 M- m+ r0 e) X9 H$ ^3 f) g, Z! C4 `
    Stage/1..3/;
      u& W& ]3 b2 APXS(Person,Stage): T, X;
    4 g" M9 n9 \. F$ P6 o+ k1 VPXP(Person,Person)|&1 #LT# &2: Y;
    " c/ a  j' x* d/ v8 W- c$ cENDSETS
    6 O/ m9 Y( q- h3 A* l8 zDATA: : G0 c! ~" i* U  [- S2 v
    T=13, 15, 20, 10 , 20 , 18, 20, 16, 10, 8, 10, 15; " d* x6 E( X6 d9 B0 s1 D
    ENDDATA
    9 a& h1 F4 a' Z! ][obj] min=MAXT;
    4 c" m$ R" I9 |8 ]2 C/ t% GMAXT>= @max(PXS(i,j)|j#EQ#@size(stage):x(i,j)+t(i,j)); ! S# V( e8 P- k5 p( h. m3 b! ^
    ! 只有参加完前一个阶段的面试后才能进入下一个阶段; , g8 u5 ]  H8 F, O" M) x- V
    @for(PXS(i,j)|j#LT#@size(stage):[ORDER]x(i,j)+t(i,j)<x(i,j+1)); 6 O. h* G4 e7 T& c! R: w; A
    ! 同一时间只能面试1名同学; - v0 S$ w2 U6 P# T  N0 R- T5 @
    @for(Stage(j):   , v/ T* k( Q! ^* H/ ^
        @for(PXP(i,k):[SORT1]x(i,j)+t(i,j)-x(k,j)<MAXT*Y(i,k));  3 u( x4 n% _5 M5 m( E& V
        @for(PXP(i,k):[SORT2]x(k,j)+t(k,j)-x(i,j)<MAXT*(1-Y(i,k))));
    9 L+ ~3 ?6 i, C) j4 h( X* L* c* a- [@for(PXP: @bin(y)); 5 V! [) z  R; p( l" O
    end
    ) `2 k6 Y4 n+ Z, K计算结果为,所有面试完成至少需要 84min,面试顺序为 4-1-2-3(丁-甲- 乙-丙)。早上 8:00 面试开始,最早 9:24 面试可以全部结束。
    . X3 M- k) t' B————————————————8 |: z  i/ m, p6 e0 d. B4 M
    版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    , D  h  D# Q5 Z9 K; @原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89387723
    / P( t2 s" s" y% b0 `. Q3 u7 j/ l% E1 Q* P' G
    6 P" k# I( O- g; N
    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-12 06:20 , Processed in 0.418298 second(s), 51 queries .

    回顶部