12
返回列表 发新帖
楼主: jasusy
跳转到指定楼层
上一主题 下一主题
收起左侧

求助求助:interval schedule, n room for most number of meetings with priority

🔗
magicsets 2018-3-3 05:09:47 | 只看该作者
全局:
本帖最后由 magicsets 于 2018-3-3 05:13 编辑
eejchen 发表于 2018-3-3 03:29
这道题lz会做了吗?感觉好难啊。。。

这道题目首先可以做个转换,将priority转为weight,只要保证如下性质:
(1) 相同priority有相同weight
(2) 高priority的weight大于所有比其低的priority的weight之和

然后求最大化weight总和的调度就可以了,算法参见这篇文章:
E. M. Arkin and E. B. Silverberg. 1987. Scheduling jobs with fixed start and end times. Discrete Appl. Math. 18, 1 (November 1987), 1-8.

https://ac.els-cdn.com/0166218X8 ... d9bfd070dc50e546bfe

时间复杂度O(n^2 log(n))


关于转换priority到weight,比如说楼主给的输入:
  1. "meeting 1" -- 100 (priority)
  2. "meeting 2" -- 100
  3. "meeting 3" -- 100
  4. "meeting 4" -- 75
  5. "meeting 5" -- 90
复制代码
那么一个可行转换如下:
  1. "meeting 1" -- 4 (weight)
  2. "meeting 2" -- 4
  3. "meeting 3" -- 4
  4. "meeting 4" -- 1
  5. "meeting 5" -- 2
复制代码
这样算法在最大化weight时,一定会优先高priority(因为所有低priority的weight加起来也没有一个高priority的weight大)

评分

参与人数 1大米 +3 收起 理由
eejchen + 3 给你点个赞!

查看全部评分

回复

使用道具 举报

🔗
eejchen 2018-3-3 22:54:28 | 只看该作者
全局:
magicsets 发表于 2018-3-3 05:09
这道题目首先可以做个转换,将priority转为weight,只要保证如下性质:
(1) 相同priority有相同weight
...

谢谢这位童鞋的解答!不明觉厉,先看看推荐的文章再说。。。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表