QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1513|回复: 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,请问他们最早何时能离开公司?) ~  e) p3 r1 @% l  {1 [

    " Y3 H2 A' A9 v+ m: n  U& O) L5 S5 [" O. m' C& U3 p, ]) z
      E6 Z7 U3 Z$ b
    1 建立模型
    " J: m, V  A& U* X  W" Y. h$ ]3 e   实际上,这个问题就是要安排 4 名同学的面试顺序,使完成全部面试所花费的时 间最少。 9 {* q' `9 _* i. c3 B( @

    % ?5 c* E- C8 v) X8 e# h  为第i名同学参加第 j 阶段面试需要的时间(已知),令   表示第i名同学参加第 j 阶段面试的开始时间(不妨记早上 8:00 面试开始为 0 时刻) (i=1,2,3,4 ; j =1,2,3),T 为完成全部面试所花费的最少时间。
    9 e# h( h. A! L+ c0 u* \2 v6 M+ d8 i: `& S' U! O3 J/ Y
    优化目标为                            (1)1 C7 Q1 E, j* u  f* g$ P. Y* ^( k
    , R$ W: @$ o% J# D: j: |
    约束条件:1 J6 q, a. c' t/ Z

    4 ?9 F6 `. m4 `: U+ y1)时间先后次序约束(每人只有参加完前一个阶段的面试后才能进入下一个阶段):                                (2)2 a" c+ N/ v& ~9 @4 a

    7 U7 x8 `4 q3 `# m2 )每个阶段 j 同一时间只能面试 1 名同学:用  0− 1 变量  表示第k 名同学是否 排在第i名同学前面(1 表示“是”,0 表示“否”),则
    # l1 R) s; h6 k: C7 G& I' f# x5 C+ u: z0 A# R. P
        (3)9 N" o# e) T3 T" ]1 i+ {4 Y

    3 ]) E- B: c0 p  ~4 @1 L可以将上述非线性的优化目标(1) 改写为如下线性优化目标:& @5 B6 ^, A) x7 k1 J9 [
    # A4 Q3 i: v/ {, n2 y
                       (4)
    % G1 _$ q4 Y7 N6 I
    # K& Y" v, F+ K  o式(2)~(4)就是这个问题的  0−1  非线性规划模型(当然所有变量还有非负约束,变量   还有  0− 1约束)。 # s% D2 J! O6 a1 }, a/ V
    2 m/ u4 t" f6 G8 ~3 X" ]. O
    2  求解模型
    9 f' L2 ?5 d* y5 J* n& Q# P" m' ~编写 LINGO 程序如下:+ V8 e* D; M6 k, R
    ' W" O) g8 W, \) o; o/ [9 \
    model:* Q6 b+ S6 h$ ^, W1 K, G4 o9 i
    Title 面试问题;
    + U" i3 v, Y1 L8 j% v$ n- XSETS: Person/1..4/; + \; A; `% r* p+ H1 ^8 e
    Stage/1..3/;
    . M1 c# d$ Z& f+ w* ePXS(Person,Stage): T, X;
    ! \5 h! O: E) P0 N0 ePXP(Person,Person)|&1 #LT# &2: Y;
    ) r* G' J7 L& F7 n8 aENDSETS
    ( Y" {" X- {- h0 G3 kDATA: ( Z. |) f! x& {* b# {. l
    T=13, 15, 20, 10 , 20 , 18, 20, 16, 10, 8, 10, 15;
    1 l- Y: }3 g+ |9 WENDDATA
    2 H; F3 ?2 r, j9 R0 x% R% h[obj] min=MAXT; / d1 Q; {9 ^7 S# f
    MAXT>= @max(PXS(i,j)|j#EQ#@size(stage):x(i,j)+t(i,j));
    ( \; w  j8 }1 z- d8 l2 o! I! 只有参加完前一个阶段的面试后才能进入下一个阶段;
    * r$ X" p: D& |: `@for(PXS(i,j)|j#LT#@size(stage):[ORDER]x(i,j)+t(i,j)<x(i,j+1));
    4 l7 @7 B% _! }" L! 同一时间只能面试1名同学;
    , x0 f- h, j% k5 y! N( W@for(Stage(j):   
    & o# y: V+ v+ H! D* w1 L    @for(PXP(i,k):[SORT1]x(i,j)+t(i,j)-x(k,j)<MAXT*Y(i,k));  
    * a9 a$ ^/ }' R    @for(PXP(i,k):[SORT2]x(k,j)+t(k,j)-x(i,j)<MAXT*(1-Y(i,k))));
    ! t  D7 B8 U9 Z@for(PXP: @bin(y));
    9 \9 L' j# K3 \end 5 U0 t& o3 b, L# I" B, l2 y
    计算结果为,所有面试完成至少需要 84min,面试顺序为 4-1-2-3(丁-甲- 乙-丙)。早上 8:00 面试开始,最早 9:24 面试可以全部结束。 $ I9 `  J7 _. e' P! l! z& W+ g
    ————————————————, x8 v- C& s# m1 Y  S  o# M% e
    版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    7 x( k3 I- g4 N% y+ s8 o原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89387723+ E! M3 s6 W, u- ]  W6 z- X- J

    4 a: {( D; L7 k$ l5 l2 v! X! n/ K- Z% `
    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, 2024-4-20 18:00 , Processed in 0.406147 second(s), 50 queries .

    回顶部