ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Arrange the Bulls(状压dp)

2022-08-29 02:00:31  阅读:127  来源: 互联网

标签:int 状压 Bulls include dp Arrange


Arrange the Bulls(状压dp)

题目大意:一些牛喜欢一些地方(每头牛都有一些喜欢的地方),现在要把这些地方分配给牛,每头牛都应该分到一个地方,问有多少种分配的方法

此题拥有着状压dp的鲜明特征,N和M只有20(看见这种数据的时候往状压dp上想一想),枚举每一种状态,判断合理性。像这种两种东西匹配的状压dp的题都基本是这种套路。

AC代码

#include <cstdio>
#include <cstring>
#include <algorithm>
#include <iostream>
using namespace std;
const int maxn=20;
int dp[1<<maxn],pw[maxn+2][maxn+2];//前面存储被选走的地方是哪几个,后面是牛喜欢的地方
int N,M;
int dfs(int st,int pos)//现在是什么状态,现在这头牛是哪头
{
	if(pos==N)return 1;//到底了,方法为1
	if(~dp[st])return dp[st];//初始化为-1,判断条件就是这个
	int ans=0;
	for(int i=0;i<M;i++)
		if((st&(1<<i))==0&&pw[pos][i])
			ans+=dfs(st|(1<<i),pos+1);
	return dp[st]=ans;
}
int main(void)
{
	memset(dp,-1,sizeof(dp));//初始化为负一是因为存在某种情况方法数为0的情况
	scanf("%d %d",&N,&M);
	for(int i=0;i<N;i++)
	{
		int x;scanf("%d",&x);
		for(int j=0;j<x;j++)
		{
			int y;scanf("%d",&y);
			y--;//因为这里的地方是从1开始的,而这里我用二进制的1<<0表示第一位,所以要减一
			pw[i][y]=1;
		}
	}
	cout<<dfs(0,0)<<endl;
	return 0;
}

啊啊啊!!!要与网路流的匹配区分开来,两个的数据量就很不同好吧。

标签:int,状压,Bulls,include,dp,Arrange
来源: https://www.cnblogs.com/WUTONGHUA02/p/16634632.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有