[状压dp]HDOJ1565 方格取数(1)
中文题~~ 题意略
$n\le 20$ ! 很明显是状压!
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <climits>
#include <cctype>
#include <cmath>
#include <string>
#include <sstream>
#include <iostream>
#include <algorithm>
#include <iomanip>
using namespace std;
#include <queue>
#include <stack>
#include <vector>
#include <deque>
#include <set>
#include <map>
typedef long long LL;
typedef long double LD;
#define pi acos(-1.0)
#define lson l, m, rt<<1
#define rson m+1, r, rt<<1|1
typedef pair<int, int> PI;
typedef pair<int, PI> PP;
#ifdef _WIN32
#define LLD "%I64d"
#else
#define LLD "%lld"
#endif
//#pragma comment(linker, "/STACK:1024000000,1024000000")
//LL quick(LL a, LL b){LL ans=1;while(b){if(b & 1)ans*=a;a=a*a;b>>=1;}return ans;}
//inline int read(){char ch=' ';int ans=0;while(ch<'0' || ch>'9')ch=getchar();while(ch<='9' && ch>='0'){ans=ans*10+ch-'0';ch=getchar();}return ans;}
//inline void print(LL x){printf(LLD, x);puts("");}
//inline void read(double &x){char c = getchar();while(c < '0') c = getchar();x = c - '0'; c = getchar();while(c >= '0'){x = x * 10 + (c - '0'); c = getchar();}} int mp[][];
int dp[][<<]; // n格为一个状态
int p[<<], d;
void pre() //先记录所有的合法状态 即不相邻
{
d=;
for(int i=;i<(<<);i++)
if((i & (i<<))==)
p[d++]=i;
}
int main()
{
#ifndef ONLINE_JUDGE
freopen("in.txt", "r", stdin);
freopen("out.txt", "w", stdout);
#endif
pre();
int n;
while(~scanf("%d", &n))
{
for(int i=;i<n;i++)
for(int j=;j<n;j++)
scanf("%d", &mp[i][j]);
memset(dp, , sizeof(dp));
int cur=;
for(int i=;i<n;i++)
{
for(int k=;k<d;k++)
{
int sum=;
if(p[k]>=(<<n)) // 算是优化吧 没有就tle了
break;
for(int j=;j<n;j++)
if(p[k] & (<<j))
sum+=mp[i][j];
for(int j=;j<d;j++)
{
if(p[j]>=(<<n)) // 算是优化吧 没有就tle了
break;
if((p[k] & p[j])==)
dp[cur][p[k]]=max(dp[cur][p[k]], dp[cur^][p[j]]+sum);
}
}
cur^=;
}
cur^=;
int ans=;
for(int i=;i<(<<n);i++)
ans=max(ans, dp[cur][i]);
printf("%d\n", ans);
}
return ;
}
HDOJ 1565
[状压dp]HDOJ1565 方格取数(1)的更多相关文章
- 暑假集训Day2 状压dp  特殊方格棋盘
		首先声明 : 这是个很easy的题 可这和我会做有什么关系 题目大意: 在n*n的方格棋盘上放置n个车,某些格子不能放,求使它们不能互相攻击的方案总数. 注意:同一行或同一列只能有一个车,否则会相互攻 ... 
- 四维DP之方格取数
		题目描述 传送门 设有N*N的方格图(N<=20,我们将其中的某些方格中填入正整数,而其他的方格中则放入数字0.如下图所示(见样例): 某人从图的左上角的A(1,1) 点出发,可以向下行走,也可 ... 
- 状压DP之集合选数
		题目 [HNOI2012]集合选数 <集合论与图论>这门课程有一道作业题,要求同学们求出{1, 2, 3, 4, 5}的所有满足以 下条件的子集:若 x 在该子集中,则 2x 和 3x 不 ... 
- HDU 6984 - Tree Planting(数据分治+状压 dp)
		题面传送门 傻逼卡常屑题/bs/bs,大概现场过得人比较少的原因就是它比较卡常罢(Fog 首先对于这样的题我们很难直接维护,不过注意到这个 \(n=300\) 给得很灵性,\(k\) 比较小和 \(k ... 
- HDU 1565&1569 方格取数系列(状压DP或者最大流)
		方格取数(2) Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total S ... 
- HDU 1565 - 方格取数(1) - [状压DP][网络流 - 最大点权独立集和最小点权覆盖集]
		题目链接:https://cn.vjudge.net/problem/HDU-1565 Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32 ... 
- hdu 2167 方格取数 【状压dp】(经典)
		<题目链接> 题目大意: 给出一些数字组成的n*n阶矩阵,这些数字都在[10,99]内,并且这个矩阵的 3<=n<=15,从这个矩阵中随机取出一些数字,在取完某个数字后,该数 ... 
- HDU 1565 方格取数  状压dp
		题目: 给你一个n*n的格子的棋盘,每个格子里面有一个非负数. 从中取出若干个数,使得任意的两个数所在的格子没有公共边,就是说所取的数所在的2个格子不能相邻,并且取出的数的和最大. Input 包括多 ... 
- HDU1565 方格取数(1) —— 状压DP  or  插头DP(轮廓线更新) or 二分图点带权最大独立集(最小割最大流)
		题目链接:https://vjudge.net/problem/HDU-1565 方格取数(1) Time Limit: 10000/5000 MS (Java/Others) Memory L ... 
随机推荐
- js观察者模式
			观察者模式存在观察者和被观察者 被观察者的状态发生改变,通知观察者调用观察者的update方法,观察者的update方法对被观察者的状态进行检测,做出相应的操作 被观察者存在接口attach,deta ... 
- 一般处理程序生成简单的图片验证码并通过html验证用户输入的验证码是否正确
			一般处理程序生成简单的图片验证码并通过html验证用户输入的验证码是否正确 最近没事研究了下验证码的的动态生成及通过cookie实现HTML页面对用户输入的验证码的校验,简要如下: 1.写 ... 
- Android Activity常用生命周期函数
			在Activity中主要有7个常用的周期函数,他们分别是: (一)onCreate 在Activity对象被第一次创建时调用 注: 从另一个Activity返回到前一个Activity时,不会调用该函 ... 
- Linux find常见用法示例
			find命令的参数: pathname: find命令所查找的目录路径.例如用.来表示当前目录,用/来表示系统根目录.-print: find命令将匹配的文件输出到标准输出.-exec: find命令 ... 
- mysqld-nt: Out of memory (Needed 1677720 bytes)解决方法
			http://www.jb51.net/article/58726.htm 今天发现网站有点慢,发现mysql日志中提示mysqld-nt: Out of memory (Needed 1677720 ... 
- 使用javascript获取gridview中的textbox值
			<body> <form id="form1" runat="server"> <div> <asp:gridview ... 
- Oracle查询慢, 特别是更新慢问题
			近期, 客户发现查询比较慢, 特别是更新更慢. 原来是oracle listerner log太大导致. (C:\app\Administrator\diag\tnslsnr\ServerName\ ... 
- ###STL学习--迭代器
			点击查看Evernote原文. #@author: gr #@date: 2014-08-23 #@email: forgerui@gmail.com STL中的迭代器. ###stl学习 |--迭代 ... 
- 打包C#程序
			开源中国. 今天来使用VS2010对C#程序进行打包发布. 我们有一个C#程序.程序很简单,我们需要对它进行发布. Contents 步骤: 建立一个安装项目.我们得到了一个Setup1项目. 在应用 ... 
- UITableViewCell和UITableViewHeaderFooterView的重用
			不管是系统自带的还是自定义的UITableViewCell,对于它们合理的使用都是决定一个UITableView的性能的关键因素.应该确保以下三条: UITableViewCell的重复利用:首先对象 ... 
