QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2818|回复: 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,请问他们最早何时能离开公司?  h( q3 B2 O* N0 ~9 m* J' y$ I8 H2 x/ O

      R) M5 g% {4 x7 ?' B- y, [
    2 p( k3 {* P6 Z5 v2 ^. b$ A" u7 z/ g: q1 K. s8 l3 b
    1 建立模型
    7 \5 a) W: ]; |" U   实际上,这个问题就是要安排 4 名同学的面试顺序,使完成全部面试所花费的时 间最少。 % e2 V# P7 H6 d) I4 \: C: z

    & ]' _# H6 F" L  为第i名同学参加第 j 阶段面试需要的时间(已知),令   表示第i名同学参加第 j 阶段面试的开始时间(不妨记早上 8:00 面试开始为 0 时刻) (i=1,2,3,4 ; j =1,2,3),T 为完成全部面试所花费的最少时间。 0 P5 a8 r& G1 E$ W, g' K/ y
    9 A- Y7 h3 W0 {) h3 w
    优化目标为                            (1)0 S9 J* @% J" b. @! K% M: e

    ; s# \5 N' U+ A8 y  o约束条件:
    & Y) b( b6 c# ?) c& S" D% s- `6 i, w  a( G9 t; t6 C' E" N7 ]
    1)时间先后次序约束(每人只有参加完前一个阶段的面试后才能进入下一个阶段):                                (2)( h! B( R: v5 W

    " {0 M4 [: p  A3 |5 A+ ~( I2 )每个阶段 j 同一时间只能面试 1 名同学:用  0− 1 变量  表示第k 名同学是否 排在第i名同学前面(1 表示“是”,0 表示“否”),则 $ W4 f, w' l: M' S/ S) {" c
    4 h( H4 t8 h. L
        (3)
    5 N3 X- a. A( q) n3 O% Z3 i3 w( B, p1 x6 D
    可以将上述非线性的优化目标(1) 改写为如下线性优化目标:
    7 t) {# B4 S8 `2 Q, t- |9 N2 Q! Y# U; ?% J: [
                       (4)  m5 _- `  x+ J

    8 o: Q' Y  G( e5 C0 M式(2)~(4)就是这个问题的  0−1  非线性规划模型(当然所有变量还有非负约束,变量   还有  0− 1约束)。   G/ H2 t4 G6 d

    / M3 j. F! u% ^4 F* n1 K! }2  求解模型 " s: s* K" K) c! s! @6 J& D
    编写 LINGO 程序如下:
    $ o% \1 }4 q% V2 b0 V6 k  [$ a" T! `' i# u
    model:
    2 a8 Q- S1 b$ o: KTitle 面试问题;
    2 x4 l4 m6 ^/ [* j: ]% eSETS: Person/1..4/; / |9 }) U3 i* g0 z. h
    Stage/1..3/;
    $ g7 j$ [' e' A3 }. q+ K0 g# ~PXS(Person,Stage): T, X; 5 M# |' M8 n. Y% q( o" n3 `
    PXP(Person,Person)|&1 #LT# &2: Y;
    7 |& o% E! C# }2 i4 cENDSETS
    0 A/ P: P; h& ?1 P7 [, J/ [DATA: " C2 P- k( k# I. M' B) w
    T=13, 15, 20, 10 , 20 , 18, 20, 16, 10, 8, 10, 15;
    , w! n$ O, A1 y# f0 h! X- w) aENDDATA
    ' o# p6 v9 L: m) m. h% S( Q[obj] min=MAXT;
    6 K2 w% {6 S: P" p' RMAXT>= @max(PXS(i,j)|j#EQ#@size(stage):x(i,j)+t(i,j)); ! s' X5 S$ i5 p" X
    ! 只有参加完前一个阶段的面试后才能进入下一个阶段; & x6 [& F& ~; U. ^: P+ Z
    @for(PXS(i,j)|j#LT#@size(stage):[ORDER]x(i,j)+t(i,j)<x(i,j+1)); , V' d  h" ^1 P/ A+ Y) O" l
    ! 同一时间只能面试1名同学;
    2 D/ X5 b7 x, j4 ^5 Y@for(Stage(j):   ( Y: d4 k+ r/ h
        @for(PXP(i,k):[SORT1]x(i,j)+t(i,j)-x(k,j)<MAXT*Y(i,k));  
    ( U+ K$ c: v2 Z" R4 \    @for(PXP(i,k):[SORT2]x(k,j)+t(k,j)-x(i,j)<MAXT*(1-Y(i,k)))); 4 p- D) ^! _$ m! L+ A& G) }# Q
    @for(PXP: @bin(y)); ! B8 X, ?9 u( @. L$ d0 d* o: X
    end
    ! [6 H+ a' K5 e+ Y1 e) k  q计算结果为,所有面试完成至少需要 84min,面试顺序为 4-1-2-3(丁-甲- 乙-丙)。早上 8:00 面试开始,最早 9:24 面试可以全部结束。
    ( ?' g2 V7 T7 }7 f: l  n————————————————
    2 w2 M9 n3 V; r$ G& c, X  b" ~版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。' a+ u6 v- T( z
    原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89387723
    ; h, T$ Q( N: k' X3 }4 u9 y8 e0 ]1 w" ?- n

    0 J# h  Y/ y" {: b
    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-11 04:07 , Processed in 0.287854 second(s), 51 queries .

    回顶部