码迷,mamicode.com
首页 > 其他好文 > 详细

刷题之路_2

时间:2019-03-31 09:27:16      阅读:128      评论:0      收藏:0      [点我收藏+]

标签:很多   工作   最大   ref   价值   存储   没有   discuss   结束   

原题

神奇的一道没办法划分类别的dp题。

看上去就像背包,有时间有费用

但试了背包的做法发现不对啊,只能弄出最大费用或最小价值

卡在从后往前转移什么,应该怎么转移的阶段上,

没有意识到由于数据范围小,没有任务的空闲时间是可以直接加1解决的orz

从后往前转移空闲的时间,

以有任务的时间点作为转移阶段和决策点,

以任务结束时对应的空闲时间作为转移对象。

//left questions

  1. 从后往前递推的必要性

原文
此时有任务(不在工作状态)就必须选,有很多个就选一个,所以当这个时间只有一个状态开始的时候,我们是没有任何的话说的,但是如果有很多的任务同时开始,我们要选取最优的那个取决这个任务结束后的情况,但是任务结束后的情况我们之前有没有推过,所以我们要倒着推

2.f[1]不是空闲时间最长的原因

在进行状态转移时只在任务开始点进行转移,任务进行中的时间仍被视作“空闲时间”+1,这样导致f[i]存储的值不一定与其定义相吻合,但由于任务进行过程中的f[i]不会被转移,所以对题目最终解没有影响

刷题之路_2

标签:很多   工作   最大   ref   价值   存储   没有   discuss   结束   

原文地址:https://www.cnblogs.com/StarOnTheWay/p/10629209.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!