POJ 2441 Arrange the Bulls 状压dp
题目链接:
http://poj.org/problem?id=2441
Arrange the Bulls
Time Limit: 4000MSMemory Limit: 65536K
#### 问题描述
> Farmer Johnson's Bulls love playing basketball very much. But none of them would like to play basketball with the other bulls because they believe that the others are all very weak. Farmer Johnson has N cows (we number the cows from 1 to N) and M barns (we number the barns from 1 to M), which is his bulls' basketball fields. However, his bulls are all very captious, they only like to play in some specific barns, and don’t want to share a barn with the others.
>
> So it is difficult for Farmer Johnson to arrange his bulls, he wants you to help him. Of course, find one solution is easy, but your task is to find how many solutions there are.
>
> You should know that a solution is a situation that every bull can play basketball in a barn he likes and no two bulls share a barn.
>
> To make the problem a little easy, it is assumed that the number of solutions will not exceed 10000000.
输入
In the first line of input contains two integers N and M (1 <= N <= 20, 1 <= M <= 20). Then come N lines. The i-th line first contains an integer P (1 <= P <= M) referring to the number of barns cow i likes to play in. Then follow P integers, which give the number of there P barns.
输出
Print a single integer in a line, which is the number of solutions.
样例输入
3 4
2 1 4
2 1 3
2 2 4
样例输出
4
题意
有n只牛,m个体育场,每只牛只会去若干个自己喜欢的体育场,现在要分配n只牛到n个不同的体育场,问总共有多少种分配方案。
题解
dp[i][j]表示分配前i只牛在状态为j的体育场的总方案数。
#include<map>
#include<set>
#include<cmath>
#include<queue>
#include<stack>
#include<ctime>
#include<vector>
#include<cstdio>
#include<string>
#include<bitset>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<functional>
using namespace std;
#define X first
#define Y second
#define mkp make_pair
#define lson (o<<1)
#define rson ((o<<1)|1)
#define mid (l+(r-l)/2)
#define sz() size()
#define pb(v) push_back(v)
#define all(o) (o).begin(),(o).end()
#define clr(a,v) memset(a,v,sizeof(a))
#define bug(a) cout<<#a<<" = "<<a<<endl
#define rep(i,a,b) for(int i=a;i<(b);i++)
#define scf scanf
#define prf printf
typedef int LL;
typedef vector<int> VI;
typedef pair<int,int> PII;
typedef vector<pair<int,int> > VPII;
const int INF=0x3f3f3f3f;
const LL INFL=10000000000000000LL;
const double eps=1e-9;
const double PI = acos(-1.0);
//start----------------------------------------------------------------------
const int maxn=20;
int dp[2][1<<maxn];
///sumv统计二进制中1的个数
int sumv[1<<maxn];
int n,m;
bool mp[maxn][maxn];
void pre(){
    clr(sumv,0);
    rep(i,0,(1<<maxn)){
        rep(j,0,maxn){
            if(i&(1<<j)) sumv[i]++;
        }
    }
}
void init(){
    clr(mp,0);
}
int main() {
    pre();
    while(scf("%d%d",&n,&m)==2&&n) {
        init();
        rep(i,0,n){
            int cnt; scf("%d",&cnt);
            while(cnt--){
                int v; scf("%d",&v);
                v--;
                mp[i][v]=true;
            }
        }
        int pre=0,cur=1;
        clr(dp[cur],0);
        ///初始化
        for(int j=0;j<m;j++){
            if(mp[0][j]){
                dp[cur][1<<j]=1;
            }
        }
        for(int i=1;i<n;i++){
            swap(pre,cur);
            clr(dp[cur],0);
            for(int j=0;j<m;j++){
                if(mp[i][j]==0) continue;
                for(int k=0;k<(1<<m);k++){
                    if(k&(1<<j)) continue;
                    dp[cur][k^(1<<j)]+=dp[pre][k];
                }
            }
        }
        int ans=0;
        for(int i=0;i<(1<<m);i++){
            if(sumv[i]==n) ans+=dp[cur][i];
        }
        prf("%d\n",ans);
    }
    return 0;
}
//end-----------------------------------------------------------------------POJ 2441 Arrange the Bulls 状压dp的更多相关文章
- poj 2441 Arrange the Bulls
		Arrange the Bulls Time Limit: 4000MS Memory Limit: 65536K Total Submissions: 5427 Accepted: 2069 ... 
- POJ 1185 炮兵阵地(状压DP)
		炮兵阵地 Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 26426 Accepted: 10185 Descriptio ... 
- POJ 2411 Mondriaan's Dream -- 状压DP
		题目:Mondriaan's Dream 链接:http://poj.org/problem?id=2411 题意:用 1*2 的瓷砖去填 n*m 的地板,问有多少种填法. 思路: 很久很久以前便做过 ... 
- POJ 2411 Mondriaan's Dream ——状压DP 插头DP
		[题目分析] 用1*2的牌铺满n*m的格子. 刚开始用到动规想写一个n*m*2^m,写了半天才知道会有重复的情况. So Sad. 然后想到数据范围这么小,爆搜好了.于是把每一种状态对应的转移都搜了出 ... 
- poj 2288 Islands and Bridges ——状压DP
		题目:http://poj.org/problem?id=2288 状压挺明显的: 一开始写了(记忆化)搜索,但一直T: #include<iostream> #include<cs ... 
- 【POJ 2923】Relocation(状压DP+DP)
		题意是给你n个物品,每次两辆车运,容量分别是c1,c2,求最少运送次数.好像不是很好想,我看了网上的题解才做出来.先用状压DP计算i状态下,第一辆可以运送的重量,用该状态的重量总和-第一辆可以运送的, ... 
- POJ 1185 炮兵阵地 (状压DP)
		题目链接 题意 : 中文题不详述. 思路 :状压DP,1表示该位置放炮弹,0表示不放.dp[i][j][k],代表第 i 行的状态为k时第i-1行的状态为 j 时放置的最大炮弹数.只是注意判断的时候不 ... 
- 动态规划晋级——POJ 3254 Corn Fields【状压DP】
		转载请注明出处:http://blog.csdn.net/a1dark 分析:刚开始学状压DP比较困难.多看看就发现其实也没有想象中那么难.这道题由于列数较小.所以将行压缩成二进制来看.首先处理第一行 ... 
- POJ 1185 炮兵阵地 【状压DP】
		<题目链接> 题目大意: 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地(用"H" 表示),也可能是平 ... 
随机推荐
- dategate的用法
			菜鸟教程上的说法是这样: delegate() 方法为指定的元素(属于被选元素的子元素)添加一个或多个事件处理程序,并规定当这些事件发生时运行的函数. 使用 delegate() 方法的事件处理程序适 ... 
- 2018-11-26 BIG DATA ANALYSIS
- 自学tensorflow——2.使用tensorflow计算线性回归模型
			废话不多说,直接开始 1.首先,导入所需的模块: import numpy as np import os import tensorflow as tf 关闭tensorflow输出的一大堆硬件信息 ... 
- Duplicate entry '' for key 'username'
			一.报错信息: ERROR 2019-04-22 02:00:29,971 exceptions 30 [<wechat.views.WixinView object at 0x7f3bb01d ... 
- 消息队列ZeroMQ
			消息队列概念 消息队列技术是分布式应用间交换信息的一种技术.消息队列可以驻留在内存或者磁盘上,队列存储消息直到它们被应用程序读走.通过消息队列,应用程序可以独立的执行,它们不需要知道彼此的位置,或者在 ... 
- AngularJS 从DOM中获取scope
			节选官方文档: 原文:https://docs.angularjs.org/guide/scope scope是附加在DOM上,使用了ng-app指令的DOM就是root scope.一般是<h ... 
- 菜鸟vimer成长记——第4.2章、编程插件
			简介 这部分的插件是与编程相关的插件.主要涉及两大块:所有编程语言通用的插件,以及各个语言独有的插件.插件的数量和合理性,这可能是一个不断累积和修正的过程. 个人感觉,现在比较适合sh,html,ma ... 
- 多栏布局与JS实现瀑布流
			css3属性之多栏布局与JS实现瀑布流 背景:之前打算自己总结一下flex布局的知识点,发现自己无从下手,原因在何处:我反思了一下,其实原因很简单,使用的次数少,更多的时间使用了百分比,浮动和定位解决 ... 
- mysql mtr写入数据
			BEGIN; --disable_query_log --let $rows= 100 WHILE($rows) { --eval INSERT INTO t1 (a) VALUES ( $rows ... 
- C#    string  的一点属性、方法什么的
			今天学的基本可以说是都属于方法和属性 下面这两句话非常重要,确实非常重要 凡是可以 “ . ” 出来的,前面是黑色的小扳手的:属性 紫色的立方体的:方法 这个对于以后自学帮助是不小的,当然, ... 
