QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2823|回复: 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,请问他们最早何时能离开公司?& J5 ^; U+ ~0 O8 Q! W

    & @/ E  o/ @, O0 Z3 t* f8 z+ I8 d4 r4 [  W7 ^+ j7 X2 j) {: r
    . H1 |# J+ F/ D6 p; W5 u
    1 建立模型
    1 W# D' O0 v% C" C2 k6 o% ^   实际上,这个问题就是要安排 4 名同学的面试顺序,使完成全部面试所花费的时 间最少。
    ; W& o4 V5 M8 d3 c$ y  u# r9 w
    , V( T1 A# h1 Y) [( }6 |; A  为第i名同学参加第 j 阶段面试需要的时间(已知),令   表示第i名同学参加第 j 阶段面试的开始时间(不妨记早上 8:00 面试开始为 0 时刻) (i=1,2,3,4 ; j =1,2,3),T 为完成全部面试所花费的最少时间。
    6 L( b+ g# T$ Y1 ]4 J" K4 I/ X3 _1 b) I
    优化目标为                            (1)
    & b! ?5 N5 |1 g; f* F& L/ O& _' |5 u3 ~; |  A3 n
    约束条件:
    % K* T- B* ]  G1 G" A: N
    3 X  a4 h& i% A! S4 ^& e; I! U1)时间先后次序约束(每人只有参加完前一个阶段的面试后才能进入下一个阶段):                                (2)
    8 a% F" t; H) X+ G% t5 E& V1 S. b5 N  [& L/ v
    2 )每个阶段 j 同一时间只能面试 1 名同学:用  0− 1 变量  表示第k 名同学是否 排在第i名同学前面(1 表示“是”,0 表示“否”),则 ' b( ]' n  H- e. v  n

    , ]$ h# o! s$ f% v8 ]! H% l# Z( e    (3)
      l7 Z7 t' K( w6 k) G: q. k$ q# V) p* A; e" o1 P/ u
    可以将上述非线性的优化目标(1) 改写为如下线性优化目标:4 m( y' A1 O  L( i/ z. R: s: ^

    6 I% Y, B4 o& u7 |                   (4)% e5 K3 d$ r3 l7 u2 h! u& y& [

    ) @( j9 l4 L2 O) a+ K% w式(2)~(4)就是这个问题的  0−1  非线性规划模型(当然所有变量还有非负约束,变量   还有  0− 1约束)。 . W/ b8 X" `8 h
    " s" q+ z, x5 y# e' h
    2  求解模型
    4 E. h0 i8 H1 r) Y编写 LINGO 程序如下:
    9 C0 w8 ^5 L2 L% {& Z; m1 a. o1 v7 `4 |
    model:
    - O4 e% d1 G* p6 r) j, t" e' m( [Title 面试问题; 3 j  j. I: m% c* `/ ^2 N5 S
    SETS: Person/1..4/;
    * {  W& u0 h% O$ @1 C. \Stage/1..3/;
    4 |% S! _' E6 V" i) b) ]+ aPXS(Person,Stage): T, X;
    4 g  `, Y2 U; A( [PXP(Person,Person)|&1 #LT# &2: Y; 8 Q0 a) _$ e. v
    ENDSETS * s4 f' ]# k; w( |! @  J
    DATA:
    ) b0 `# V% p# c4 K4 \4 H. Q% j3 z6 JT=13, 15, 20, 10 , 20 , 18, 20, 16, 10, 8, 10, 15;
    " P+ b  i- I0 O+ ]! w$ |! ]3 y: v' L. LENDDATA
    8 @, V! t0 e2 b# F[obj] min=MAXT; / r, T$ J  Q  Q8 Q
    MAXT>= @max(PXS(i,j)|j#EQ#@size(stage):x(i,j)+t(i,j));
    * z- X3 t5 c& Q& I# t! 只有参加完前一个阶段的面试后才能进入下一个阶段;
    . O  p6 s! A1 K2 A@for(PXS(i,j)|j#LT#@size(stage):[ORDER]x(i,j)+t(i,j)<x(i,j+1)); ! C3 L# ~6 I! b% Q7 O7 Z, H7 h
    ! 同一时间只能面试1名同学;
    3 q# u4 p# K' e* y" y: R% U@for(Stage(j):   
    6 S3 i# O( F* `3 e6 b    @for(PXP(i,k):[SORT1]x(i,j)+t(i,j)-x(k,j)<MAXT*Y(i,k));    f* }/ [. W! e' S* Z1 |! b, R
        @for(PXP(i,k):[SORT2]x(k,j)+t(k,j)-x(i,j)<MAXT*(1-Y(i,k))));
    5 ]+ Z& l; W/ l@for(PXP: @bin(y));
    & e+ U. L' c7 f- Z7 eend : t6 X" O  q& f2 i- w, X; J
    计算结果为,所有面试完成至少需要 84min,面试顺序为 4-1-2-3(丁-甲- 乙-丙)。早上 8:00 面试开始,最早 9:24 面试可以全部结束。
    # ~9 I! P% [% z4 _————————————————
    , e( w% Y0 s, l) J版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    2 d! K6 s4 ]( ~/ I原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89387723+ W# S) X) S7 C$ o* U* C

    + U$ N" P8 a* s# x: K6 G9 r
    2 l( H+ F* z, Y1 N0 @
    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-6-12 08:41 , Processed in 0.413527 second(s), 51 queries .

    回顶部