【BZOJ】4316: 小C的独立集 静态仙人掌
【题意】给定仙人掌图,求最大独立集(选择最大的点集使得点间无连边)。n<=50000,m<=60000。
【算法】DFS处理仙人掌图
【题解】参考:【BZOJ】1023: [SHOI2008]cactus仙人掌图
对仙人掌进行无向图的点双连通分量Tarjan算法,树边正常DP,环边(low[y]<=dfn[x])无视。
每个环在其深度最小的点整体处理(找到(u,v)只须fa[v]≠u&&dfn[y]>dfn[x])。
DP的做法参考:【BZOJ】1040: [ZJOI2008]骑士 环套树DP
#include<cstdio>
#include<cctype>
#include<algorithm>
using namespace std;
int read(){
char c;int s=,t=;
while(!isdigit(c=getchar()))if(c=='-')t=-;
do{s=s*+c-'';}while(isdigit(c=getchar()));
return s*t;
}
const int maxn=;
struct edge{int v,from;}e[maxn*];
int n,m,tot,first[maxn],fa[maxn],f[maxn][],g[maxn][];
int dfn[maxn],low[maxn],dfsnum=;
void insert(int u,int v){tot++;e[tot].v=v;e[tot].from=first[u];first[u]=tot;} void solve(int u,int v){
int cnt=;
for(int i=v;i!=fa[u];i=fa[i]){cnt++;g[cnt][]=f[i][];g[cnt][]=f[i][];}
for(int i=;i<=cnt;i++){
g[i][]+=max(g[i-][],g[i-][]);
g[i][]+=g[i-][];
}
f[u][]=g[cnt][];
cnt=;
for(int i=v;i!=fa[u];i=fa[i]){cnt++;g[cnt][]=f[i][];g[cnt][]=f[i][];}
g[][]=-0x3f3f3f3f;
for(int i=;i<=cnt;i++){
g[i][]+=max(g[i-][],g[i-][]);
g[i][]+=g[i-][];
}
f[u][]=g[cnt][];
}
void tarjan(int x,int father){
dfn[x]=low[x]=++dfsnum;f[x][]=;f[x][]=;
for(int i=first[x];i;i=e[i].from)if(i!=father){
int y=e[i].v;
if(!dfn[y]){
fa[y]=x;
tarjan(y,i);
low[x]=min(low[x],low[y]);
}else low[x]=min(low[x],dfn[y]);
if(low[y]>dfn[x]){
f[x][]+=max(f[y][],f[y][]);
f[x][]+=f[y][];
}
}
for(int i=first[x];i;i=e[i].from)if(fa[e[i].v]!=x&&dfn[e[i].v]>dfn[x])solve(x,e[i].v);
}
int main(){
n=read();m=read();
for(int i=;i<=m;i++){
int u=read(),v=read();
insert(u,v);insert(v,u);
}
tarjan(,);
printf("%d",max(f[][],f[][]));
return ;
}
【BZOJ】4316: 小C的独立集 静态仙人掌的更多相关文章
- bzoj 4316: 小C的独立集【仙人掌dp】
		参考:https://www.cnblogs.com/clrs97/p/7518696.html 其实和圆方树没什么关系 设f[i][j][k]为i点选/不选,这个环的底选不选 这个底的定义是设u为这 ... 
- BZOJ  4316: 小C的独立集 仙人掌 + 树形DP
		4316: 小C的独立集 Time Limit: 10 Sec Memory Limit: 128 MB Description 图论小王子小C经常虐菜,特别是在图论方面,经常把小D虐得很惨很惨. ... 
- BZOJ 4316: 小C的独立集 解题报告
		4316: 小C的独立集 Description 图论小王子小C经常虐菜,特别是在图论方面,经常把小D虐得很惨很惨. 这不,小C让小D去求一个无向图的最大独立集,通俗地讲就是:在无向图中选出若干个点, ... 
- BZOJ 4316: 小C的独立集
		4316: 小C的独立集 思路:先将树上的转移做好.然后环上的转移就是强制最上面的的点选或者不选,然后在环上跑一遍转移就可以了. 代码: #pragma GCC optimize(2) #pragma ... 
- BZOJ.4316.小C的独立集(仙人掌 DP)
		题目链接 \(Description\) 求一棵仙人掌的最大独立集. \(Solution\) 如果是树,那么 \(f[i][0/1]\) 表示当前点不取/取的最大独立集大小,直接DP即可,即 \(f ... 
- 【刷题】BZOJ 4316 小C的独立集
		Description 图论小王子小C经常虐菜,特别是在图论方面,经常把小D虐得很惨很惨. 这不,小C让小D去求一个无向图的最大独立集,通俗地讲就是:在无向图中选出若干个点,这些点互相没有边连接,并使 ... 
- 【BZOJ4316】小C的独立集(仙人掌,动态规划)
		[BZOJ4316]小C的独立集(仙人掌,动态规划) 题面 BZOJ 题解 除了普通的动态规划以外,这题还可以用仙人掌的做法来做. 这里没有必要把圆方树给建立出来 \(Tarjan\)的本质其实就是一 ... 
- BZOJ4316 小C的独立集  【仙人掌】
		题目 图论小王子小C经常虐菜,特别是在图论方面,经常把小D虐得很惨很惨. 这不,小C让小D去求一个无向图的最大独立集,通俗地讲就是:在无向图中选出若干个点,这些点互相没有边连接,并使取出的点尽量多. ... 
- 2019.02.07 bzoj4316: 小C的独立集(仙人掌+树形dp)
		传送门 题意:给出一个仙人掌森林求其最大独立集. 思路:如果没有环可以用经典的树形dpdpdp解决. fi,0/1f_{i,0/1}fi,0/1表示第iii个点不选/选的最大独立集. 然后fi,0+ ... 
随机推荐
- SQL 语句(增删改查)
			一.增:有4种方法1.使用insert插入单行数据: --语法:insert [into] <表名> [列名] values <列值> 例:insert into Strden ... 
- 学生导师互选系统(php代码规范)
			学生导师互选系统(php代码规范) php编码规范 组名:一不小心就火了 负责项目:学生导师互选系统(安卓端) 编写目的 为了更好的提高团队的的合作效率,保证开发的有效性和合理性,并可最大程度的提高程 ... 
- 【leetcode】300.Longest Increasing Subsequence
			Given an unsorted array of integers, find the length of longest increasing subsequence. For example, ... 
- 【Linux】- 六个超赞的字符画生成器
			ASCII是一个非常吸引人的字符编码系统,在计算机,通讯设备,以及其他设备中,通过它来用代码表示字符.新生代的人可能会觉得它已经过时了,但是那些熟悉它的人会懂得ASCII是多么的独特.我们在这里为你准 ... 
- Kafka及Spring Cloud Stream
			安装 下载kafka http://mirrors.hust.edu.cn/apache/kafka/2.0.0/kafka_2.11-2.0.0.tgz kafka最为重要三个配置依次为:broke ... 
- UVA11734_Big Number of Teams will Solve This
			题意很简单,本身也是个水题. 给你两个字符串,如果两个串完全相同,那么输出yes:如果两串只是空格的不同,出去空格后完全相同,那么输出Output Format Error,否则输出Wrong Ans ... 
- HDU——1788 Chinese remainder theorem again
			再来一发水体,是为了照应上一发水题. 再次也特别说明一下,白书上的中国剩余定理的模板不靠谱. 老子刚刚用柏树上的模板交上去,简直wa出翔啊. 下面隆重推荐安叔版同余方程组的求解方法. 反正这个版本十分 ... 
- HDU 4767——Bell
			昨天比赛被虐的这个题目. 今天听斌牛讲过他的思路后就A掉了. 题目的意思是要你求出bell数的第n项对95041567取模. 首先,95041567=31*37*41*43*47: 然后取模就是先分别 ... 
- day 03 字符串 for 循环
			1.有变量量name = "aleX leNb" 完成如下操作: 1)移除 name 变量量对应的值两边的空格,并输出处理理结果 name = "aleX leNb&qu ... 
- QoS专题-第1期-QoS理论篇
			QoS理论篇 1 QoS的产生 随着网络技术的飞速发展,IP网络已经从当初的单一数据网络向集成数据.语音.视频.游戏的多业务网络转变.网络中所承载的数据呈几何级倍数增长,而且这些业务对网络带 ... 
