Codeforces 题面传送门 & 洛谷题面传送门

首先这个消消乐的顺着消的过程看起来有点难受,DP 起来有点困难。考虑对其进行一个转化:将所有出场的人按照攻击力从小到大合并,然后每次将两个攻击力为 \(l\) 的合并为一个攻击力为 \(l+1\) 的人,答案加上 \(c_{l+1}\),如果发现攻击力为 \(l\) 的人 \(\le 1\) 那就继续合并攻击力为 \(l+1\) 的人,不难发现这个过程与原题的过程等价。

接下来考虑如何 DP 求解原问题。我们将序列翻转,这样单调不减就可以转化为单调不升,方便我们的合并过程。设 \(dp_{x,i,j}\) 表示当前考虑了前 \(x\) 个人,合并到攻击力 \(=i\) 的人,目前攻击力 \(=i\) 的人有 \(j\) 个,转移就新加入一个人时,令 \(dp_{x,l_x,j+1}\leftarrow dp_{x-1,l_x,j}-s_x+c_{l_x}\),然后从 \(l_x\) 开始往 \(n\) 枚举更新合并的贡献即可,具体来说 \(dp_{x,i+1,j/2}\leftarrow dp_{x,i,j}+\dfrac{j}{2}·c_{i+1}\)。你可能会疑惑为什么不直接一次性合并完所有攻击力为 \(i\) 的人直到不能合并为止,这是因为你有可能出现合并到一半又进来了新的人的情况,这种情况下就要一步步合并。\(x\) 那一维可以去掉这样空间复杂度可以达到平方。直接转移单次复杂度是 \(n^2\) 的,总复杂度 \(n^3\),无法通过。不过注意到在合并的过程中,我们的 \(j\) 只可能达到 \(\dfrac{x}{2^{i-l_x}}\),因此 \(j\) 的枚举只用枚举到 \(\dfrac{x}{2^{i-l_x}}\) 即可,这样总复杂度就是平方。

const int MAXN=2000;
int n,m,l[MAXN+5],s[MAXN+5],dp[MAXN*2+5][MAXN+5],c[MAXN*2+5];
int main(){
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++) scanf("%d",&l[i]);
for(int i=1;i<=n;i++) scanf("%d",&s[i]);
for(int i=1;i<=n+m;i++) scanf("%d",&c[i]);
memset(dp,192,sizeof(dp));
for(int i=1;i<=n+m;i++) dp[i][0]=0;
for(int i=n;i;i--){
for(int j=n;j;j--) chkmax(dp[l[i]][j],dp[l[i]][j-1]+c[l[i]]-s[i]);
for(int j=l[i];j<=n+m;j++) for(int k=0;k<=(n>>(j-l[i]));k++)
chkmax(dp[j+1][k>>1],dp[j][k]+1ll*(k>>1)*c[j+1]);
} printf("%d\n",dp[n+m][0]);
return 0;
}

Codeforces 1322D - Reality Show(DP)的更多相关文章

  1. Codeforces Gym101341K:Competitions(DP)

    http://codeforces.com/gym/101341/problem/K 题意:给出n个区间,每个区间有一个l, r, w,代表区间左端点右端点和区间的权值,现在可以选取一些区间,要求选择 ...

  2. codeforces 711C Coloring Trees(DP)

    题目链接:http://codeforces.com/problemset/problem/711/C O(n^4)的复杂度,以为会超时的 思路:dp[i][j][k]表示第i棵数用颜色k涂完后bea ...

  3. codeforces#1154F. Shovels Shop (dp)

    题目链接: http://codeforces.com/contest/1154/problem/F 题意: 有$n$个物品,$m$条优惠 每个优惠的格式是,买$x_i$个物品,最便宜的$y_i$个物 ...

  4. Codeforces 1051 D.Bicolorings(DP)

    Codeforces 1051 D.Bicolorings 题意:一个2×n的方格纸,用黑白给格子涂色,要求分出k个连通块,求方案数. 思路:用0,1表示黑白,则第i列可以涂00,01,10,11,( ...

  5. Codeforces 1207C Gas Pipeline (dp)

    题目链接:http://codeforces.com/problemset/problem/1207/C 题目大意是给一条道路修管道,相隔一个单位的管道有两个柱子支撑,管道柱子高度可以是1可以是2,道 ...

  6. Codeforces 704C - Black Widow(dp)

    Codeforces 题目传送门 & 洛谷题目传送门 u1s1 感觉这种题被评到 *2900 是因为细节太繁琐了,而不是题目本身的难度,所以我切掉这种题根本不能说明什么-- 首先题目中有一个非 ...

  7. Codeforces 682B New Skateboard(DP)

    题目大概说给一个数字组成的字符串问有几个子串其代表的数字(可以有前导0)能被4整除. dp[i][m]表示字符串0...i中mod 4为m的后缀的个数 通过在i-1添加str[i]字符转移,或者以st ...

  8. Codeforces 543D Road Improvement(DP)

    题目链接 Solution 比较明显的树形DP模型. 首先可以先用一次DFS求出以1为根时,sum[i](以i为子树的根时,满足要求的子树的个数). 考虑将根从i变换到它的儿子j时,sum[i]产生的 ...

  9. Codeforces 543C Remembering Strings(DP)

    题意比较麻烦 见题目链接 Solution: 非常值得注意的一点是题目给出的范围只有20,而众所周知字母表里有26个字母.于是显然对一个字母进行变换后是不影响到其它字符串的. 20的范围恰好又是常见状 ...

随机推荐

  1. C++ 与 Visual Studio 2019 和 WSL(二)

    终端 A more integrated terminal experience | Visual Studio Blog (microsoft.com) Say hello to the new V ...

  2. python中的信号通信 blinker

    信号: 信号是一种通知或者说通信的方式,信号分为发送方和接收方.发送方发送一中信号,接收方收到信号的进程会跳入信号处理函数,执行完后再跳回原来的位置继续执行.常见的linux中的信号,通过键盘输入Ct ...

  3. JDK里常见容器总结

    自己总结.   扩容 线程安全   是否支持null 的key 说明 hashmap 2*length 否   是 1.8以后增加红黑树.提高检索效率 hashtable   是   否 官方不建议使 ...

  4. 2020BUAA软工个人博客作业-软件案例分析

    2020BUAA软工个人博客作业-软件案例分析 17373010 杜博玮 项目 内容 这个作业属于哪个课程 2020春季计算机学院软件工程(罗杰 任健) 这个作业的要求在哪里 个人博客作业-软件案例分 ...

  5. Noip模拟61 2021.9.25

    T1 交通 考场上想了一个$NPC$.应该吧,是要求出图里面的所有可行的不重复欧拉路 无数种做法都无法解出,时间也都耗在这个上面的,于是就考的挺惨的 以后要是觉得当前思路不可做,就试着换一换思路,千万 ...

  6. 热身训练4 Eighty seven

    Eighty seven 简要题意: n个卡片,其中第i个卡片的数值为$a[i]$.一共q次询问,每次询问将删去其中3个卡片(可能删除若干相同的卡片)后,问能否选出10个卡片,数值之和等于87. n≤ ...

  7. IPv6(诞生原因、数据报格式、与IPv4的不同、地址表现形式、基本地址类型、IPv6与IPv4的过渡策略)

    文章转自:https://blog.csdn.net/weixin_43914604/article/details/105297642 学习课程:<2019王道考研计算机网络> 学习目的 ...

  8. PCIE学习笔记--TLP Header详解(三)

    目录篇地址为:http://blog.chinaaet.com/justlxy/p/5100053481 Completions Completions的TLP Header的格式如下图所示: 这里来 ...

  9. 0x03

    指数级枚举:1到n任意选取的所有方案数: #include<bits/stdc++.h> using namespace std; int n,a[1100],vis[1100],cnt, ...

  10. poj 2724 Purifying Machine(二分图最大匹配)

    题意: 有2^N块奶酪,编号为00...0到11..1. 有一台机器,有N个开关.每个开关可以置0或置1,或者置*.但是规定N个开关中最多只能有一个开关置*. 一旦打开机器的开关,机器将根据N个开关的 ...