codeforces#1290E2 - Rotate Columns (hard version)(子集dp)
题目链接:
https://codeforces.com/contest/1209/problem/E2
题意:
给出$n$行和$m$列
每次操作循环挪动某列一次
可以执行无数次这样的操作
让每行最大值的累加和最大
数据范围:
$1\leq n \leq 12$
$1\leq m \leq 20000$
分析:
定义$dp[i][j]$,考虑前$i$列,选择状态为$j$的最大值
$ans=dp[m][(1<<n)-1]$
$dp[i][j]$可以由$dp[i-1][k]$转移,$k$是$j$的二进制子集
$easy$难度还是比较好写的
$hard$难度需要预处理,和保留最多$n$列
easy代码:
const int N=5;
const int M=105;
int n,m,B[M],A[N][M];
int f[1<<N][M];
int main( )
{
int i,j,k,t,z,r,u,G,T=read( );
while(T--)
{
read(n);
read(m);;
for(i=1; i<=n; i++)
for(j=1; j<=m; j++)
A[i][j]=read( );
int S=(1<<n)-1;
for(i=1; i<=m; i++)
for(j=0; j<=S; j++)
f[j][i]=0;
for(i=1; i<=m; i++)
{
for(j=0; j<=S; j++)
{
for(k=j;; k=(k-1)&j)
{
u=0;
for(t=0; t<n; t++)
{
r=0;
for(z=1; z<=n; z++)
{
G=((z-1)+t)%n+1;
if(((1<<(G-1))&j)&&(!((1<<(G-1))&k)))
r+=A[z][i];
}
u=max(u,r);
}
f[j][i]=max(f[j][i],f[k][i-1]+u);
if(!k) break;
}
}
}
printf("%d\n",f[S][n]);
}
return 0;
}
hard代码:
#include<bits/stdc++.h>
#define ll long long
#define pii pair<int,int>
using namespace std;
const int maxn=12+10;
const int maxm=2007;
int num[maxn][maxm];
pii p[maxn*maxm];
int lis[maxn][maxn],cnt;
int dp[maxn][(1<<12)+10],f[maxn][(1<<12)+10];
set<int>se;
int main()
{
int T;
scanf("%d",&T);
while(T--){
int n,m;
scanf("%d %d",&n,&m);
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
scanf("%d",&num[i][j]);
p[(i-1)*m+j]=make_pair(num[i][j],j);
}
}
sort(p+1,p+1+n*m);
se.clear();
for(int i=0;i<n*m;i++){
se.insert(p[n*m-i].second);
if(se.size()==n)break;//保留最多n列
}
int cnt=0;
for(auto i:se){
cnt++;
for(int j=1;j<=n;j++)
lis[j][cnt]=num[j][i];
}
m=cnt; int len=(1<<n);
memset(f,0,sizeof(f));
for(int i=1;i<=m;i++)//预处理每列选择状态的最优解
for(int choose=0;choose<len;choose++){ for(int j=1;j<=n;j++){
int res=0;
for(int k=1;k<=n;k++){
int g=(k-1+j)%n+1;
if((1<<(g-1))&choose)res+=lis[k][i];
}
f[i][choose]=max(res,f[i][choose]);
} }
memset(dp,0,sizeof(dp));
for(int i=1;i<=m;i++){
for(int choose=0;choose<len;choose++){
for(int shift=choose;;shift=((shift-1)&choose)){//枚举choose的子集
int v=choose-(shift&choose);
dp[i][choose]=max(dp[i][choose],dp[i-1][shift]+f[i][v]);
if(shift==0)break;
}
}
}
printf("%d\n",dp[m][len-1]);
}
return 0;
}
codeforces#1290E2 - Rotate Columns (hard version)(子集dp)的更多相关文章
- Codeforces 1209E2. Rotate Columns (hard version)
传送门 发现 $n$ 很小,考虑状压 $dp$,但是如果强行枚举列并枚举置换再转移复杂度太高了 考虑推推结论,发现我们只要保留列最大值最大的 $n$ 列即可,证明好像挺显然: 假设我们让列最大值比较小 ...
- Codeforces Round #584 E2. Rotate Columns (hard version)
链接: https://codeforces.com/contest/1209/problem/E2 题意: This is a harder version of the problem. The ...
- Codeforces 219D. Choosing Capital for Treeland (树dp)
题目链接:http://codeforces.com/contest/219/problem/D 树dp //#pragma comment(linker, "/STACK:10240000 ...
- [BZOJ4416][SHOI2013]阶乘字符串(子集DP)
怎么也没想到是子集DP,想到了应该就没什么难度了. 首先n>21时必定为NO. g[i][j]表示位置i后的第一个字母j在哪个位置,n*21求出. f[S]表示S的所有全排列子序列出现的最后末尾 ...
- loj 300 [CTSC2017]吉夫特 【Lucas定理 + 子集dp】
题目链接 loj300 题解 orz litble 膜完题解后,突然有一个简单的想法: 考虑到\(2\)是质数,考虑Lucas定理: \[{n \choose m} = \prod_{i = 1} { ...
- hdu 5823 color II —— 子集DP
题目:http://acm.hdu.edu.cn/showproblem.php?pid=5823 看博客:http://www.cnblogs.com/SilverNebula/p/5929550. ...
- BZOJ 4006 [JLOI2015]管道连接(斯坦纳树+子集DP)
明显是一道斯坦纳树的题. 然而这题只需要属性相同的点互相连接. 我们还是照常先套路求出\(ans[s]\). 然后对\(ans[s]\)做子集DP即可. 具体看代码. #include<iost ...
- BZOJ 2560(子集DP+容斥原理)
2560: 串珠子 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 757 Solved: 497[Submit][Status][Discuss] ...
- [CodeForces - 1272D] Remove One Element 【线性dp】
[CodeForces - 1272D] Remove One Element [线性dp] 标签:题解 codeforces题解 dp 线性dp 题目描述 Time limit 2000 ms Me ...
随机推荐
- 数据仓库之抽取数据:通过bcp命令行导入数据
原文:数据仓库之抽取数据:通过bcp命令行导入数据 在做数据仓库时,最重要的就是ETL的开发,而在ETL开发中的第一步,就是要从原OLTP系统中抽取数据到过渡区中,再对这个过渡区中的数据进行转换,最后 ...
- JDBC 复习5 mysql 的自增长主键 auto_increment
MySQL 自增长主键 (1)如果把一个NULL插入到一个AUTO_INCREMENT数据列里去,MySQL将自动生成下一个序列编号.编号从1开始,并1为基数递增. (2)把0插入AUTO_INCRE ...
- 关于Vue中页面(父组件)下拉,页面中的子组件加载更多数据的实现方法
一个项目中存在很多这种情况:父组件(页面)中的子组件需要做下拉加载更多的需求,但是这个下拉到底部的动作只能通过监控页面(父组件)来完成 这就需要父子组件之间的通信,代码如下: 1. 建立一个用于父子组 ...
- LeetCode 【1】 Two Sum --001
5月箴言 住进布达拉宫,我是雪域最大的王.流浪在拉萨街头,我是世间最美的情郎.—— 仓央嘉措 从本周起每周研究一个算法,并以swift实现之 001 -- Two Sum (两数之和) 题干英文版: ...
- MySQL主从复制以及在本地环境搭建
MySQL主从复制原理: master(主服务器),slave(从服务器) MySQL master 将数据变更写入二进制日志( binary log, 其中记录叫做二进制日志事binary log ...
- 爬虫必备的web知识
爬虫定义.分类和流程 爬虫的定义: 网络爬虫(又被称为网页蜘蛛,网络机器人)就是模拟浏览器发送网络请求,接收请求响应,一种按照一定的规则,自动地抓取互联网信息的程序.爬虫就是模拟浏览器的行为,越像越好 ...
- 笔记本电脑安装jupyterthemes
上午准备在老笔记本上也装上jupyter themes,竟然遇到一堆问题: 首先直接 pip install jupyterthemes 参考:https://blog.csdn.net/Jinlon ...
- 一步一步pwn路由器之rop技术实战
前言 本文由 本人 首发于 先知安全技术社区: https://xianzhi.aliyun.com/forum/user/5274 这次程序也是 DVRF 里面的,他的路径是 pwnable/She ...
- phpstudy如何配置域名
其他选项菜单=>站点域名管理=>站点管理填入信息后点击“新增”按钮=>点击“保存设置并生成配置文件”按钮=>打开hosts=>127.0.0.1 www.gohosts. ...
- C# 之 .net core -- MVC模式的显示、增、删、改
上一篇介绍数据的创建连接,接下来就是基本的增删改 一.右键添加.控制器 二.选择这个带试图的 三.其他的不要动,点击添加 四.执行一下,改下url 试一下他的增删改. 其实自己写的话可以用form表单 ...