codeforces 285 D. Permutation Sum 状压 dfs打表
题意:
如果有2个排列a,b,定义序列c为:
c[i] = (a[i] + b[i] - 2) % n + 1
但是,明显c不一定是一个排列
现在,给出排列的长度n (1 <= n <= 16)
问有多少种a,b的排列的组合的方案,使得得到的c也是一个排列
排列的组合a = x,b = y 与 排列的组合a = y,b = x算是2种方案
思路:
有3个排列,不妨假设排列a 为1,2,3,...,n
这样结果再 * n! 就是答案
考虑状压dp
j是一个16位的数,记录b的n个数被用了哪些数
f(i,j)表示a用了1~i,b用了j记录的那些数,产生的c的前i个的方案数
init : f(0,0) = 1
ans = f(n,(1<<n)-1) * n!转移方程:
没法转移阿,因为我们还必须知道c哪些数用了,哪些数没有用
如果再加一维记录c的状态的话,数组开不下了
那就写成搜索的形式了
dfs(u,v,w) 表示a用了1~u,b,c分别用了v,w记录的那些数
if(u == n + 1) ans++;
但是这样会超时啊,1 <= n <= 16,这么小,那就直接打表了
代码:
//File Name: cf285D.cpp
//Author: long
//Mail: 736726758@qq.com
//Created Time: 2016年07月09日 星期六 16时44分05秒 #include <stdio.h>
#include <string.h>
#include <algorithm>
#include <iostream> #define LL long long using namespace std; const int MOD = (int)1e9 + ; LL ans,n;
LL jie[];
int res[] = {,,,,,,,,,,,,,,,,}; void init(){
jie[] = ;
for(int i=;i<;i++)
jie[i] = i * jie[i-] % MOD;
//ans = 0;
//dfs(1,0,0);
} void dfs(int a,int b,int c){
if(a == n + ){
ans++;
if(ans >= MOD)
ans -= MOD;
return ;
}
int v;
for(int i=;i<n;i++){
if(((<<i) & b) == ){
v = (i + a - ) % n;
if(((<<v) & c) == )
dfs(a+,b|(<<i),c|(<<v));
}
}
} int main(){
init();
while(~scanf("%d",&n)){
printf("%d\n",res[n]);
}
return ;
}
codeforces 285 D. Permutation Sum 状压 dfs打表的更多相关文章
- ZOJ 1609 Equivalence(状压+dfs减枝)
ZOJ Problem Set - 1609 Equivalence Time Limit: 5 Seconds Memory Limit: 32768 KB When learning m ...
- [Codeforces 1208D]Restore Permutation (树状数组)
[Codeforces 1208D]Restore Permutation (树状数组) 题面 有一个长度为n的排列a.对于每个元素i,\(s_i\)表示\(\sum_{j=1,a_j<a_i} ...
- bzoj1725: [Usaco2006 Nov]Corn Fields牧场的安排(状压dfs)
1725: [Usaco2006 Nov]Corn Fields牧场的安排 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 1122 Solved: 80 ...
- 状压dfs小记
一点前(tu)言(cao) 真的考起dfs来可谓是什么都能往dfs上套 状压不止能dp,还能与dfs结合成为搜索好(duliu)题 剪枝卡常司空见惯(打开题解一看并不是纯dfs,emmmm) 开始正文 ...
- 【bzoj5161】最长上升子序列 状压dp+打表
题目描述 现在有一个长度为n的随机排列,求它的最长上升子序列长度的期望. 为了避免精度误差,你只需要输出答案模998244353的余数. 输入 输入只包含一个正整数n.N<=28 输出 输出只包 ...
- UVALive 6255:Kingdoms(状压DFS)
题目链接 题意 给出n个王国和n*n的矩阵,mp[i][j] 代表第 i 个王国欠第 j 个王国 mp[i][j] 块钱.如果当前的王国处于负债状态,那么这个王国就会被消除,和它相连的王国的债务都会被 ...
- Codeforces Round #363 LRU(概率 状压DP)
状压DP: 先不考虑数量k, dp[i]表示状态为i的概率,状态转移方程为dp[i | (1 << j)] += dp[i],最后考虑k, 状态表示中1的数量为k的表示可行解. #incl ...
- Codeforces 429C Guess the Tree(状压DP+贪心)
吐槽:这道题真心坑...做了一整天,我太蒻了... 题意 构造一棵 $ n $ 个节点的树,要求满足以下条件: 每个非叶子节点至少包含2个儿子: 以节点 $ i $ 为根的子树中必须包含 $ c_i ...
- JZYZOJ1530 [haoi2013]开关控制 状压 dfs 折半搜索
http://172.20.6.3/Problem_Show.asp?id=1530 元宵节快要到了,某城市人民公园将举办一次灯展.Dr.Kong准备设计出一个奇妙的展品,他计划将编号为1到N的N(1 ...
随机推荐
- scala言语基础学习十二
- 黑马程序员——JAVA基础之JDK1.5新特性高级for循环和可变参数
------- android培训.java培训.期待与您交流! ---------- 高级for循环 格式: for(数据类型 变量名 : 被遍历的集合(Collection)或者数组) { ...
- 论文笔记之:Playing Atari with Deep Reinforcement Learning
Playing Atari with Deep Reinforcement Learning <Computer Science>, 2013 Abstract: 本文提出了一种深度学习方 ...
- 论文笔记之:Multiple Object Recognition With Visual Attention
Multiple Object Recognition With Visual Attention Google DeepMind ICRL 2015 本文提出了一种基于 attention 的用 ...
- JSBinding + SharpKit / Coroutine支持
首先得深入了解协程的原理.如果还没有完全理解,建议看这篇: http://wiki.unity3d.com/index.php/CoroutineScheduler 另外还要对 JavaScript ...
- rsyslog日志服务的配置文件分析
基于rsyslog日志服务的日志 在不同的LINUX系统,实现的软件略有不同. syslog,rsyslog,syslog-ng,用于实现系统日志的管理. [root@asianux4 ~]# rpm ...
- Myeclipse10中出现Cannot return from outside a function or method错误提示
最近发现myeclipse10中有几处bug 比如: Cannot return from outside a function or method onClick="return chec ...
- 二十四种设计模式:组合模式(Composite Pattern)
组合模式(Composite Pattern) 介绍将对象组合成树形结构以表示"部分-整体"的层次结构.它使得客户对单个对象和复合对象的使用具有一致性.示例有一个Message实体 ...
- 使用Path语法取得对象的值
借鉴了http://stackoverflow.com/questions/4473928/c-sharp-dynamic-string-property-path public class ...
- linux终端-console
echo $TERM 在ssh上是xterm 在console上是linux setterm -foreground black -background white -store http://blo ...