题面&翻译

题解

虽然

m

m

m 很大,但是

n

n

n 很小,因此题目允许我们在

O

(

n

m

)

O(nm)

O(nm) 以内解决这道题。

定义一个 dp[i][j]=0/1
如果是

i

i

i 个操作时能不能停在

j

j

j 点的话,我们会发现,从第一个最小的

i

i

i 满足

d

p

[

i

]

[

j

]

=

1

dp[i][j]=1

dp[i][j]=1 开始,后面的

d

p

[

i

+

1...

n

]

[

j

]

dp[i+1...n][j]

dp[i+1...n][j] 一定都为 1 了,因为后面的操作都可以令

a

=

0

a=0

a=0 然后不动。因此我们完全没必要定义第一维。

那就定义一个 dp[i] 表示

i

i

i 时的最小可能操作
我们会发现,由于

y

i

y_i

yi​ 的限制,我们缺少次数的信息,无法转移,因此要同时记录该信息。

dp[i][j] 表示

i

i

i 时的最小可能操作,满足此时操作已经执行了

j

j

j 次总行了吧?
事实上这很荒谬。首先,

i

i

i 时的最小可能操作是确定的,跟你强制的这个执行次数 “j” 并没关系,而且更严谨地说,操作数是因,执行次数是果,总不能把果放进状态吧。其次,既然最小操作数确定,那么到达

i

i

i 时该操作的执行次数肯定越少越好。

因此我们定义 (pair<int,int>) dp[i] ,第一个值表示

i

i

i 时的最小可能操作,第二个值表示到

i

i

i 时的最小执行次数
此时两个 pair 取较小的,刚好是先比较第一位,再比较第二位。
方便起见,令

N

e

x

t

i

(

k

)

{\rm Next}_i(k)

Nexti​(k) 表示从位置

k

k

k 开始,执行一次

i

i

i 类操作后走到的位置,那么有如下转移:

  1. {

    d

    p

    [

    i

    ]

    .

    f

    i

    r

    s

    t

    ,

    d

    p

    [

    i

    ]

    .

    s

    e

    c

    o

    n

    d

    +

    1

    }

    d

    p

    [

    N

    e

    x

    t

    d

    p

    [

    i

    ]

    .

    f

    i

    r

    s

    t

    (

    i

    )

    ]

    \{dp[i].{\rm first},dp[i].{\rm second}+1\}\rightarrow dp[{\rm Next}_{dp[i].{\rm first}}(i)]

    {dp[i].first,dp[i].second+1}→dp[Nextdp[i].first​(i)]

  2. {

    j

    ,

    1

    }

    d

    p

    [

    N

    e

    x

    t

    j

    (

    i

    )

    ]

    \{j,1\}\rightarrow dp[{\rm Next}_{j}(i)]

    {j,1}→dp[Nextj​(i)]

第一个转移的条件是执行次数没到

y

y

y 的限制,第二个转移的条件是

j

j

j 大于当前的

d

p

[

i

]

.

f

i

r

s

t

dp[i].{\rm first}

dp[i].first。

状态数

O

(

m

)

O(m)

O(m),转移复杂度

O

(

n

)

O(n)

O(n) ,总复杂度

O

(

n

m

)

O(nm)

O(nm).

CODE

#include<set>
#include<queue>
#include<cmath>
#include<vector>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
#define MAXN 100005
#define ENDL putchar('\n')
#define LL long long
#define DB double
#define lowbit(x) ((-x) & (x))
#define int LL
LL read() {
LL f = 1,x = 0;char s = getchar();
while(s < '0' || s > '9') {if(s=='-')f = -f;s = getchar();}
while(s >= '0' && s <= '9') {x=x*10+(s-'0');s = getchar();}
return f * x;
}
int n,m,i,j,s,o,k;
int ti[MAXN],yy[MAXN];
LL xx[MAXN];
int tm[MAXN],ai[MAXN];
void add(int i,int tim,int Ai) {
if(i < 1 || i > n) return ;
if(tim < tm[i]) tm[i]=tim,ai[i]=Ai;
else if(tim == tm[i]) ai[i] = min(ai[i],Ai);
// printf(" %d : %d,%d\n",i,tm[i],ai[i]);
return ;
}
int adnm(LL x,int i) {return (x+100000ll*i+99999ll)/100000;}
int munm(LL x,int i) {return (x*i+99999ll)/100000;}
signed main() {
m = read();n = read();
for(int i = 1;i <= m;i ++) {
ti[i] = read();
xx[i] = read();
yy[i] = read();
}
for(int i = 1;i <= n;i ++) tm[i] = 0x3f3f3f3f;
tm[0] = 0; ai[0] = 0;
for(int i = 0;i <= n;i ++) {
if(i > 0) printf("%lld ",tm[i] >= 0x3f3f3f3f ? -1:tm[i]);
if(tm[i] < 0x3f3f3f3f) {
int t = tm[i];
if(ti[t] == 1 && ai[i] < yy[t]) add(adnm(xx[t],i),t,ai[i]+1);
else if(ti[t] == 2 && ai[i] < yy[t]) add(munm(xx[t],i),t,ai[i]+1);
for(int j = t+1;j <= m;j ++) {
if(ti[j] == 1) add(adnm(xx[j],i),j,1);
else if(ti[j] == 2) add(munm(xx[j],i),j,1);
}
}
}ENDL;
return 0;
}

[CF1498D] Bananas in a Microwave (DP)的更多相关文章

  1. LightOJ 1033 Generating Palindromes(dp)

    LightOJ 1033  Generating Palindromes(dp) 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid= ...

  2. lightOJ 1047 Neighbor House (DP)

    lightOJ 1047   Neighbor House (DP) 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=87730# ...

  3. UVA11125 - Arrange Some Marbles(dp)

    UVA11125 - Arrange Some Marbles(dp) option=com_onlinejudge&Itemid=8&category=24&page=sho ...

  4. 【POJ 3071】 Football(DP)

    [POJ 3071] Football(DP) Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 4350   Accepted ...

  5. 初探动态规划(DP)

    学习qzz的命名,来写一篇关于动态规划(dp)的入门博客. 动态规划应该算是一个入门oier的坑,动态规划的抽象即神奇之处,让很多萌新 萌比. 写这篇博客的目标,就是想要用一些容易理解的方式,讲解入门 ...

  6. Tour(dp)

    Tour(dp) 给定平面上n(n<=1000)个点的坐标(按照x递增的顺序),各点x坐标不同,且均为正整数.请设计一条路线,从最左边的点出发,走到最右边的点后再返回,要求除了最左点和最右点之外 ...

  7. 2017百度之星资格赛 1003:度度熊与邪恶大魔王(DP)

    .navbar-nav > li.active > a { background-image: none; background-color: #058; } .navbar-invers ...

  8. Leetcode之动态规划(DP)专题-详解983. 最低票价(Minimum Cost For Tickets)

    Leetcode之动态规划(DP)专题-983. 最低票价(Minimum Cost For Tickets) 在一个火车旅行很受欢迎的国度,你提前一年计划了一些火车旅行.在接下来的一年里,你要旅行的 ...

  9. 最长公共子序列长度(dp)

    /// 求两个字符串的最大公共子序列长度,最长公共子序列则并不要求连续,但要求前后顺序(dp) #include <bits/stdc++.h> using namespace std; ...

随机推荐

  1. c++ RMQ

    关于 RMQ ,即 Range Maxnum (Minnum) Query .用于查询静态区间最大(最小)值, 思路基于动态规划 (DP) 思路 设 F[i][j] 为 [i,i+2j] 区间内的的最 ...

  2. hibernate-validator的基本使用

    validator是用来校验参数使用! 一般来说校验参数的工作可以放在前端去执行,但是假如有人不经过前端直接调用后端的接口呢?很可能就出现非法数据而导致一些问题,所有服务端也要做数据的校验. 前端校验 ...

  3. Kafka 的稳定性

    一.事务 1. 事务简介 1.1 事务场景 producer发的多条消息组成⼀个事务这些消息需要对consumer同时可⻅或者同时不可⻅ producer可能会给多个topic,多个partition ...

  4. PHP时间轴函数

    PHP时间轴函数可以更好的去进行用户体验.让用户动态的知道最近是什么时候,而不是死板的datatime去转换成固定的时间. 后续版本会考虑添加这个功能,代码先贴出来. function tranTim ...

  5. .NET中获取Windows的常见路径

    更新记录 本文迁移自Panda666原博客,原发布时间:2021年6月30日. 一.说明 每种平台都其预定义的规则,比如Windows平台有自己的规定.公司也有预定义的规章制度.那么在平台上开发和干活 ...

  6. 基于MybatisPlus代码生成器(2.0新版本)

    一.模块简介 1.功能亮点 实时读取库表结构元数据信息,比如表名.字段名.字段类型.注释等,选中修改后的表,点击一键生成,代码成即可提现出表结构的变化. 单表快速转化restful风格的API接口并对 ...

  7. CVPR2022 | 弱监督多标签分类中的损失问题

    前言 本文提出了一种新的弱监督多标签分类(WSML)方法,该方法拒绝或纠正大损失样本,以防止模型记忆有噪声的标签.由于没有繁重和复杂的组件,提出的方法在几个部分标签设置(包括Pascal VOC 20 ...

  8. halcon数组的一些使用

    没啥好讲的,这里对于不是数组部分的东西就不进行讲解了. area_center(RegionOpening,Area, Row, Column).使用area_center来求区域的中心和面积时,返回 ...

  9. java反序列化漏洞专项

    背景条件:java的框架,java的应用程序,使用序列化,反序列化操作非常多.在漏洞挖掘中,代码审计中,安全研究中,反序列化漏洞是个重点项,不可忽视.尤其是java应用程序的rce,10个里面有7个是 ...

  10. P2575 高手过招 题解

    题目描述 我们考虑如何把问题转换成博弈论来求解. 我们对于每一行之前都加上一个空格. 设原来这一行的空格个数是 \(C\) ,那么此时空格个数变成 \(C + 1\) . 然后按照从左到右的顺序给每一 ...