cf 11D A Simple Task(状压DP)
题意:
N个点构成的无向图,M条边描述这个无向图。
问这个无向图中共有多少个环。
(1 ≤ n ≤ 19, 0 ≤ m)
思路:
例子:
4 6
1 2
1 3
1 4
2 3
2 4
3 4
答案:7
画个图发现,直接暴力DFS有太多的重复计算。用DP。
枚举点数(状态),每个状态的起点、终点(起点可以不用枚举,因为反正是一个环,谁作为起点都一样)。
dp[S][i]:状态是S,i是终点 含义:从S中的第一个数s出发到达第i个点的方案数。如果s和i相加,总方案数ans+=dp[S][i]
dp[S][i]=sigma(dp[S'][i']) S'是去掉第i个点后的点集,i'属于S'且i'和i相连。
*结果除以2的原因:例:1-2-3-4-1 实际上和1-4-3-2-1是一样的。
代码:
int n,m;
char G[25][25];
int S[1<<19]; //全局状态
int cnS;
int P[25]; //全局指针
int cnP;
ll dp[(1<<19)+5][25];
ll ans; void finds(int nn,int fNum,int nowNum,int nowPos,int Ss){ //长度为nn,共要放fNum个,现在已放nowNum个,现在正在nowPos位置要进行第nowNum+1个放置的尝试
if(nowNum==fNum){
S[++cnS]=Ss;
return;
}
int t1=fNum-nowNum;
rep(i,nowPos,nn-t1+1){
int nSs=Ss+(1<<(i-1));
finds(nn,fNum,nowNum+1,i+1,nSs);
}
}
void calc(int nn,int S){ //总长度为nn,计算状态S哪些位置上为1,存在全局指针P【】中。
cnP=0;
rep(i,1,nn){
int t=(1<<(i-1));
if((S&t)>0){
P[++cnP]=i;
}
}
}
void init(){
cnS=0;
cnP=0;
finds(n,2,0,1,0);
mem(dp,0); rep(i,1,cnS){
int ss=S[i];
calc(n,ss);
rep(j,2,cnP){
if(G[P[1]][P[j]]==1){
dp[ss][P[j]]=1;
}
}
}
}
void solve(){
rep(i,3,n){ //状态由i个点构成
cnS=0;
cnP=0;
finds(n,i,0,1,0);
rep(tt,1,cnS){
int ss=S[tt];
calc(n,ss);
rep(j,2,cnP){
int pj=P[j]; //终点
int nss=ss-(1<<(pj-1)); //上一个状态
rep(k,2,cnP){ //枚举终点
if(k==j) continue;
if(G[pj][P[k]]==0) continue;
int pk=P[k];
dp[ss][pj]+=dp[nss][pk];
}
if(G[P[1]][pj]==1){
ans+=dp[ss][pj];
}
}
}
}
} int main(){
cin>>n>>m; mem(G,0);
while(m--){
int a,b;
scanf("%d%d",&a,&b);
G[a][b]=G[b][a]=1;
} if(n==1 || n==2){
puts("0");
}
else{
init();
ans=0;
solve();
printf("%I64d\n",ans/2);
} return 0;
}
cf 11D A Simple Task(状压DP)的更多相关文章
- CF11D A Simple Task 状压DP
传送门 \(N \leq 19\)-- 不难想到一个状压:设\(f_{i,j,k}\)表示开头为\(i\).结尾为\(j\).经过的点数二进制下为\(k\)的简单路总数,贡献答案就看\(i,j\)之间 ...
- CF 11D A Simple Task 题解
题面 这道题的数据范围一看就是dfs或状压啦~ 本文以状压的方式来讲解 f[i][j]表示目前的节点是i,已经经历过的节点的状态为j的简单环的个数: 具体的转移方程和细节请看代码: PS:(i& ...
- CF11D A Simple Task(状压DP)
\(solution:\) 思路大家应该都懂: 状压DP:\(f[i][j]\),其中 \(i\) 这一维是需要状压的,用来记录19个节点每一个是否已经走过(走过为 \(1\) ,没走为 \(0\) ...
- FZU - 2218 Simple String Problem(状压dp)
Simple String Problem Recently, you have found your interest in string theory. Here is an interestin ...
- FZU - 2218 Simple String Problem 状压dp
FZU - 2218Simple String Problem 题目大意:给一个长度为n含有k个不同字母的串,从中挑选出两个连续的子串,要求两个子串中含有不同的字符,问这样的两个子串长度乘积最大是多少 ...
- codeforces Diagrams & Tableaux1 (状压DP)
http://codeforces.com/gym/100405 D题 题在pdf里 codeforces.com/gym/100405/attachments/download/2331/20132 ...
- fzu2188 状压dp
G - Simple String Problem Time Limit:2000MS Memory Limit:32768KB 64bit IO Format:%I64d & ...
- HDU5816 Hearthstone(状压DP)
题目 Source http://acm.hdu.edu.cn/showproblem.php?pid=5816 Description Hearthstone is an online collec ...
- BZOJ-1087 互不侵犯King 状压DP+DFS预处理
1087: [SCOI2005]互不侵犯King Time Limit: 10 Sec Memory Limit: 162 MB Submit: 2337 Solved: 1366 [Submit][ ...
随机推荐
- liunx常见指令
linux目录结构 bin:存储普通命令 sbin:存储超级命令 home:存储普通用户 root:存储超级用户 usr /usr/local:下存储数据或软件,通常软件都放在其中 tmp:临时目录 ...
- swiper-wrapper轮滑组件(多组轮滑界面)间隔无效问题
在多组此种轮滑效果出现时,你需要加两个属性值,即 new Swiper('.swiper-container', { slidesPerView: 3, slidesPerColumn: 2, spa ...
- mysql给数据库表里某个字段赋随机值
UPDATE sxz_goods set sales_volume_base = round(rand() * 50) + 1 where sales_volume_base =0 ORDER BY ...
- win10系统git的安装与使用命令
一.git简介 git是一个开源的分布式版本控制系统,可以高效的进行项目版本管理.分布式相比集中式最大的区别在于:分布式开发者可以提交到本地,每个开发者通过克隆在本地机器上拷贝一个完整的git仓库. ...
- 接口测试checklist
静态测试 接口文档与设计文档对应 接口定义 接口定义与数据库定义 业务功能测试 系统全流程验证 逆向全流程验证 事务性测试 边界值测试 业务规则边界值 场景分析合理长度 场景分析合理数据量 输入.输出 ...
- JSP页面属性
一.JSP指令 <%@指令名属性名=属性值 %> page指令: 定义页面是如何解析 include指令: 静态包含 taglib指令: 在页面引入标签呢库. 1.page指令属性 imp ...
- VmWare装Linux&Centos步骤
昨晚一次偶然的机会进入飞哥的直播间,他正在将用虚拟机搭建Linux环境的步骤,自己之前也确实安装过一次,不过没什么系统性总结,过程中有些步骤还需百度查找.于是乎今天决定从零基础在过一遍流程,便是这篇博 ...
- 神器----IntelliJ IDEA基本配置
介绍 首先是百度百科对于 IDEA 的介绍 IDEA 全称 IntelliJ IDEA,是java编程语言开发的集成环境.IntelliJ在业界被公认为最好的java开发工具,尤其在智能代码助手.代码 ...
- C# .NET Core 3.1中使用 MongoDB.Driver 更新嵌套数组元素和关联的一些坑
C# .NET Core 3.1中使用 MongoDB.Driver 更新数组元素和关联的一些坑 前言: 由于工作的原因,使用的数据库由原来的 关系型数据库 MySQL.SQL Server 变成了 ...
- mapboxgl 纠偏百度地图
缘起 之前分享了mapboxgl 互联网地图纠偏插件,插件当时只集成了高德地图. 文章发布后,有小伙伴在后台留言,希望插件也能支持百度地图. 刚好国庆假期有时间就研究了一下. 插件加载瓦片原理 首先, ...