【58.75%】【BZOJ 1087】[SCOI2005]互不侵犯King
Time Limit: 10 Sec Memory Limit: 162 MB
Submit: 3040 Solved: 1786
[Submit][Status][Discuss]
Description
在N×N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案。国王能攻击到它上下左右,以及左上
左下右上右下八个方向上附近的各一个格子,共8个格子。
Input
只有一行,包含两个数N,K ( 1 <=N <=9, 0 <= K <= N * N)
Output
方案数。
Sample Input
Sample Output
【题解】
设f[i][j][k]表示在第i行的放国王的序列为k,然后前i行放了j个国王的方案数;
f[i][j][k] = ∑[i-1][j-count[k]][pre_zhuangtai];
然后就是pre_zhuangtai 要怎么和k状态配对呢?
就是说你怎么知道这两行的国王不会发生冲突?
可以用dfs预处理出来。
然后用碉堡了的位运算来获取不合法的关系。剩下的就是合法的了。
1
1
1
01
01
10
像上面3个都是不合法的会发现
x<<1 x>>1 x 分别和y进行&运算。如果大于0.就是不合法的了。
记录下某两个状态是不是合法的就可以了。
【代码】
#include <cstdio>
#include <cstring> const int MAXN = 101; int n, k, n_zt = 0, zt[MAXN], count[MAXN];
long long f[10][101][101];
bool can[MAXN][MAXN]; void dfs(int num, int pre, int zhuangtai)
{
n_zt++;
zt[n_zt] = zhuangtai;
count[n_zt] = num;
if (num >= k)
return;
for (int i = pre + 2; i <= n; i++)
dfs(num + 1, i, zhuangtai + (1 << (i - 1)));
} int main()
{
//freopen("F:\\rush.txt", "r", stdin);
memset(can, true, sizeof(can));
scanf("%d%d", &n, &k);
dfs(0, -1, 0);
for (int i = 1; i <= n_zt; i++)
for (int j = 1; j <= n_zt; j++)
if ((zt[i] & zt[j]) || ((zt[i] << 1) & zt[j]) || ((zt[i] >> 1) & zt[j]))
can[j][i] = can[i][j] = false;
for (int i = 1; i <= n_zt; i++)
f[1][count[i]][i] = 1;
for (int i = 2;i <= n;i++)//枚举当前是第几行。
for (int j = 0;j <= k;j++)//枚举当总共放了多少个国王
for (int now = 1; now <= n_zt; now++)//枚举当前行的状态是什么
{
if (j < count[now])//如果枚举当前行状态的国王数目大于当前枚举的则跳过。
continue;
for (int prezt = 1; prezt <= n_zt; prezt++)//枚举前一行的状态是什么
if (can[prezt][now] && count[prezt] + count[now] <= j)
f[i][j][now] += f[i - 1][j - count[now]][prezt];
//如果这两行符合规则.且前一行的国王的数目加上这一行的国王的数目小于等于
//当前枚举的车的数目;
//这一行贡献了count[now]个国王。则前i-1行贡献了j-count[now]个国王.
}
long long ans = 0;
for (int i = 1; i <= n_zt; i++)
ans += f[n][k][i];
printf("%lld\n", ans);
return 0;
}
【58.75%】【BZOJ 1087】[SCOI2005]互不侵犯King的更多相关文章
- BZOJ 1087: [SCOI2005]互不侵犯King [状压DP]
1087: [SCOI2005]互不侵犯King Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 3336 Solved: 1936[Submit][ ...
- bzoj 1087 [SCOI2005]互不侵犯King 状态压缩dp
1087: [SCOI2005]互不侵犯King Time Limit: 10 Sec Memory Limit: 162 MB[Submit][Status][Discuss] Descripti ...
- bzoj[1087][SCOI2005]互不侵犯King
Description 在N×N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案.国王能攻击到它上下左右,以及左上左下右上右下八个方向上附近的各一个格子,共8个格子. Input 只有一行,包 ...
- bzoj 1087: [SCOI2005]互不侵犯King【状压dp】
显然是状压,设f[i][j][k]为1到i行选j个king,并且第i行状态为k的方案数,判断是否可行然后枚举转移即可 先把可行状态预处理出来会变快 #include<iostream> # ...
- BZOJ 1087 [SCOI2005]互不侵犯King(状压DP)
题意:在N×N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案.国王能攻击到它上下左右,以及左上左下右上右下八个方向上附近的各一个格子,共8个格子.n<=9 思路:状压dp,dp[i][ ...
- BZOJ 1087 [SCOI2005]互不侵犯King ——状压DP
[题目分析] 沉迷水题,吃枣药丸. [代码] #include <cstdio> #include <cstring> #include <iostream> #i ...
- 1087: [SCOI2005]互不侵犯King
1087: [SCOI2005]互不侵犯King Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 4276 Solved: 2471[Submit][ ...
- 【BZOJ】1087: [SCOI2005]互不侵犯King(状压dp)
http://www.lydsy.com:808/JudgeOnline/problem.php?id=1087 状压dp是第一次写啊,我也是才学TAT.状压dp一般都用一个值表示集合作为dp的一个状 ...
- 【BZOJ】1087: [SCOI2005]互不侵犯King
[算法]状态压缩型DP [题解]http://www.cnblogs.com/xtx1999/p/4620227.html (orz) https://www.cnblogs.com/zbtrs/p/ ...
- 1087. [SCOI2005]互不侵犯King【状压DP】
Description 在N×N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案.国王能攻击到它上下左右,以及左上 左下右上右下八个方向上附近的各一个格子,共8个格子. Input 只有一行, ...
随机推荐
- python 字符串匹配的应用
- 模拟登录新浪微博(Python) - 转
Update: 如果只是写个小爬虫,访问需要登录的页面,采用填入cookie 的方法吧,简单粗暴有效,详细见:http://www.douban.com/note/264976536/模拟登陆有时需要 ...
- Pyhton 单行、多行注释方法
一.python单行注释的符号 井号#常被用作单行注释符号,在代码中使用#时,它右边的任何数据都会被忽略,当做是注释.类似c++的// 二.批量.多行注释的符号 多行注释是用三引号: ”’ 注释内容 ...
- SPSS函数之期和时间函数
SPSS函数之期和时间函数 CTIME.DAYS(timevalue)数值.返回 timevalue 中的天数(包括有小数位的天数),timevalue 必须为时间格式的数值或表达式,如 TIME.x ...
- MySQL整数类型字段的长度总结
MySQL还支持选择在该类型关键字后面的括号内指定整数值的显示宽度(例如,INT(4)). 该可选显示宽度规定用于显示宽度小于指定的列宽度的值时从左侧填满宽度.(类似使用LPAD函数效果) 在INT( ...
- SharpDX初学者教程第1部分:在Visual Studio 2013中设置SharpDX项目
原文 http://www.johanfalk.eu/blog/sharpdx-tutorial-part-1-setting-up-a-sharpdx-project-in-visual-studi ...
- 使用DataX同步MaxCompute数据到TableStore(原OTS)优化指南
概述 现在越来越多的技术架构下会组合使用MaxCompute和TableStore,用MaxCompute作大数据分析,计算的结果会导出到TableStore提供在线访问.MaxCompute提供海量 ...
- [翻译]Python中yield的解释
问题: Python中yield关键字的作用是什么?它做了什么? 例如,我想理解以下代码 def node._get_child_candidates(self, distance, min_dist ...
- python特性(八):生成器对象的send方法
生成器对象是一个迭代器.但是它比迭代器对象多了一些方法,它们包括send方法,throw方法和close方法.这些方法,主要是用于外部与生成器对象的交互.本文先介绍send方法. send方法有一个参 ...
- python selenium处理JS只读(12306)
12306为例 js = "document.getElementById('train_date').removeAttribute('readonly');" driver.e ...