4.3 省选模拟赛 序列游戏 dp


可以发现 某一段被删除后状态难以表示 也难以链接起来。
考虑暴力 有40分的状压dp 暴力存状态 然后枚举转移即可。最后注意和f[0]这个状态取max 不然一分都没有。
const int MAXN=12;
int f[1<<MAXN];
int a[MAXN],b[MAXN],v[MAXN],w[MAXN];
int n,maxx,ans;
int main()
{
freopen("1.in","r",stdin);
//freopen("sequence.out","w",stdout);
get(n);
if(n<=10)
{
memset(f,0xcf,sizeof(f));
rep(1,n,i)get(v[i]);
rep(1,n,i)get(a[i]);
maxx=(1<<n)-1;
f[maxx]=0;
fep(maxx,1,i)
{
if(f[i]<-INF)continue;
int top=0;
rep(1,n,j)if((i&(1<<(j-1))))b[++top]=a[j],w[top]=(1<<(j-1));
rep(1,top,j)
{
rep(1,top-j+1,k)
{
int en=k+j-1;
int flag=0,s=i;
rep(k,en,l)
{
if(l>k)
{
if(abs(b[l]-b[l-1])!=1){flag=1;break;}
if(l<en)if(b[l]<b[l-1]&&b[l]<b[l+1]){flag=1;break;}
}
s=s^w[l];
}
if(!flag)f[s]=max(f[s],f[i]+v[j]);
}
}
ans=max(ans,f[i]);
}
ans=max(ans,f[0]);
put(ans);return 0;
}
}
从上面的分析我们也可以发现难点就在于状态的表示。
正解:int f[N][N][N],g[N][N][N],last[N][N];//f[i][j][k]表示对于区间[i,j] j一定和后面的K个连成一段进行删除的最大值.
//f数组表示可能存在单个高峰 g数组和f组一样 g数组表示没有峰为单调序列。形状定义为[i,j-1]形成的形状
很遗憾不明白为什么要这样做 也看不懂这样的转移是再干嘛。
留下STD 以后填坑。
#include <algorithm>
#include <iostream>
#include <cstring>
#include <cstdio>
#include <cmath>
#include <map>
using namespace std;
const int N = 153, INF = -0x3f3f3f3f;
int n, m, ans[N], v[N], a[N], last[N][N], f[N][N][N], g[N][N][N];
map<int, int> hash;
inline void upt(int &x, const int &y) {
if (x < y) x = y;
}
char ch;
inline int read() {
int res = 0, sgn = 0;
while (ch = getchar(), ch < '0' || ch > '9') if (ch == '-') break;
ch == '-' ? sgn = 1 : res = ch - 48;
while (ch = getchar(), ch >= '0' && ch <= '9') res = res * 10 + ch - 48;
return sgn == 0 ? res : -res;
}
int main() {
freopen("1.in", "r", stdin);
// freopen("sequence.out", "w", stdout);
n = read();
for (int i = 1; i <= n; ++i) v[i] = read();
for (int i = 1; i <= n; ++i) {
a[i] = read();
if (hash[a[i]] == 0) hash[a[i]] = ++m;
}
for (int i = 1; i <= n; ++i) {
for (int j = 1; j <= m; ++j) last[i][j] = last[i - 1][j];
last[i][hash[a[i]]] = i;
}
memset(f, INF, sizeof(f));
memset(g, INF, sizeof(g));
//cout<<f[0][0][0]<<' '<<INF<<endl;
for (int i = 1; i <= n; ++i) {
for (int j = 0; j <= n; ++j)
if (i + j <= n)
f[i][i][j] = g[i][i][j] = v[j + 1];
else break;
f[i][i - 1][0] = g[i][i - 1][0] = 0;
}
for (int l = 1; l <= n; ++l)
for (int i = 1; i <= n; ++i) {
int j = i + l;
if (j > n) break;
for (int k = 0; k <= n; ++k) {
if (j + k > n) break;
upt(f[i][j][k], f[i][j - 1][0] + v[k + 1]);
upt(g[i][j][k], f[i][j - 1][0] + v[k + 1]);
int p = hash[a[j] + 1], q = hash[a[j] - 1];
for (int h = last[j][p]; h >= i; h = last[h - 1][p])
upt(f[i][j][k], f[i][h][k + 1] + f[h + 1][j - 1][0]);
for (int h = last[j][q]; h >= i; h = last[h - 1][q]) {
upt(f[i][j][k], g[i][h][k + 1] + f[h + 1][j - 1][0]);
upt(g[i][j][k], g[i][h][k + 1] + f[h + 1][j - 1][0]);
}
}
}
ans[0] = 0;
for (int i = 1; i <= n; ++i) {
upt(ans[i], ans[i - 1]);
for (int j = 0; j < i; ++j)
upt(ans[i], ans[j] + f[j + 1][i][0]);
}
printf("%d\n", ans[n]);
return 0;
}
4.3 省选模拟赛 序列游戏 dp的更多相关文章
- 4.11 省选模拟赛 序列 二分 线段树优化dp set优化dp 缩点
容易想到二分. 看到第一个条件容易想到缩点. 第二个条件自然是分段 然后让总和最小 容易想到dp. 缩点为先:我是采用了取了一个前缀最小值数组 二分+并查集缩点 当然也是可以直接采用 其他的奇奇怪怪的 ...
- 4.9 省选模拟赛 圆圈游戏 树形dp set优化建图
由于圆不存在相交的关系 所以包容关系形成了树的形态 其实是一个森林 不过加一个0点 就变成了树. 考虑对于每个圆都求出最近的包容它的点 即他的父亲.然后树形dp即可.暴力建图n^2. const in ...
- 5.10 省选模拟赛 拍卖 博弈 dp
LINK:拍卖 比赛的时候 前面时间浪费的有点多 写这道题的时候 没剩多少时间了. 随便设了一个状态 就开始做了. 果然需要认真的思考.其实 从我的状态的状态转移中可以看出所有的结论. 这里 就不再赘 ...
- 5.12 省选模拟赛 T2 贪心 dp 搜索 差分
LINK:T2 这题感觉很套路 但是不会写. 区间操作 显然直接使用dp不太行 直接爆搜也不太行复杂度太高. 容易想到差分 由于使得整个序列都为0 那么第一个数也要i差分前一个数 强行加一个0 然后 ...
- 6.3 省选模拟赛 Decompose 动态dp 树链剖分 set
LINK:Decompose 看起来很难 实际上也很难 考验选手的dp 树链剖分 矩阵乘法的能力. 容易列出dp方程 暴力dp 期望得分28. 对于链的情况 容易发现dp方程可以转矩阵乘法 然后利用线 ...
- 5.10 省选模拟赛 tree 树形dp 逆元
LINK:tree 整场比赛看起来最不可做 确是最简单的题目. 感觉很难写 不过单独考虑某个点 容易想到树形dp的状态. 设f[x]表示以x为根的子树内有黑边的方案数. 白边方案只有一种所以不用记录. ...
- 4.13 省选模拟赛 树 树形dp 卷积 NTT优化dp.
考试的时候 看到概率 看到期望我就怂 推了一波矩阵树推自闭了 发现 边权点权的什么也不是. 想到了树形dp 维护所有边的断开情况 然后发现数联通块的和再k次方过于困难. 这个时候 应该仔细观察一下 和 ...
- 【洛谷比赛】[LnOI2019]长脖子鹿省选模拟赛 T1 题解
今天是[LnOI2019]长脖子鹿省选模拟赛的时间,小编表示考的不怎么样,改了半天也只会改第一题,那也先呈上题解吧. T1:P5248 [LnOI2019SP]快速多项式变换(FPT) 一看这题就很手 ...
- [10.18模拟赛] 序列 (DP)
[10.18模拟赛] 序列 题目描述 山山有一个整数序列s1,s2,-,sn,其中1≤si≤k. 求出有多少个准确移除m个元素后不同的序列.答案模(1e9+7) 输入 输入包括几个测试用例,并且由文件 ...
随机推荐
- 详解GaussDB bufferpool缓存策略,这次彻底懂了!
摘要:华为云GaussDB(for mysql)是华为云自主研发的最新一代云原生数据库,采用计算存储分离.日志即数据的架构设计.具备极致可靠.极致性价比.多为扩展.完全可信等诸多特性. 一 .Gaus ...
- expected single matching bean but found 2: menusServiceImpl,IMenusService
问题如下: 接口也作为匹配的bean? 有点迷惑了....... 经过在网上找资料,发现和@MapperScan这个注解有关系,具体源码不止.但是这个注解会扫描路径下的所有类. 去掉这个注解就可以正常 ...
- POJ - 3463 Sightseeing 最短路计数+次短路计数
F - Sightseeing 传送门: POJ - 3463 分析 一句话题意:给你一个有向图,可能有重边,让你求从s到t最短路的条数,如果次短路的长度比最短路的长度多1,那么在加上次短路的条数. ...
- JVM零碎知识
JVM常见XX参数 查看JVM默认值 常用基本配置参数 生产环境服务器变慢,如何诊断 生产环境CPU占用过高,如何诊断 JDK自带的JVM监控和性能分析工具 jps(虚拟机进程状况工具) jinfo( ...
- C++输出三角图形
输出像这样的三角图形 3 1 1 1 1 1 1 1 1 1 1 1 1 ...
- day55 js进阶
目录 引子 一.BOM操作 1 window对象 2 window子对象 3 history对象 4 location对象(掌握) 5 弹出框 6 计时器相关 二.DOM操作 1 查找标签 1.1 直 ...
- 02 Vue指令
Vue指令 1.文本相关指令 <div id="app"> <!-- 插值表达式 --> <p>{{ msg }}</p> < ...
- 04 Django模型层: Django-model进阶
一 QuerySet对象 1.1可切片 使用Python 的切片语法来限制查询集记录的数目 .它等同于SQL 的LIMIT 和OFFSET 子句. Entry.objects.all()[:5] # ...
- java 基本语法(一) 关键字与标识符
1.java关键字的使用定义:被Java语言赋予了特殊含义,用做专门用途的字符串(单词)特点:关键字中所字母都为小写具体哪些关键字: 2.保留字:现Java版本尚未使用,但以后版本可能会作为关键字使用 ...
- java 基础(二) 搭建Java编译环境(linux系统)
jdk安装配置 首先下载JDK和JRE,这里你的需要看看你的Linux系统是多少位的,比如我的是64位的:下载JDK并指定到Download目录,JRE同样操作:解压并且配置环境: tar -zxvf ...