题意:http://www.lydsy.com/JudgeOnline/problem.php?id=1093

sol  :一开始理解错题意了QAQ,还莫名其妙写挂了QAQ,调了半天

   首先显然一个强联通分量肯定要么都属于最大半联通子图,要么都不属于

   所以先用tarjan缩点,重建后得到一个DAG

   之后我们可以发现,得到的答案一定是一条链,所以要求最长链的长度和数量

   直接dp即可,记得判重(我挂了好久QAQ)

#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
using namespace std;
const int Mx=;
int n,m,p,maxn,ans,cnt,tag,top;
int dfn[Mx],low[Mx],val[Mx],belong[Mx],stk[Mx];
int in[Mx],f[Mx],g[Mx],vis[Mx];
bool instk[Mx];
int tot,head1[Mx],head2[Mx],nxt1[*Mx],ver1[*Mx],nxt2[*Mx],ver2[*Mx];
void add1(int x,int y)
{
nxt1[++tot]=head1[x];
ver1[tot]=y;
head1[x]=tot;
}
void add2(int x,int y)
{
nxt2[++tot]=head2[x];
ver2[tot]=y;
head2[x]=tot;
in[y]++;
}
void tarjan(int x)
{
dfn[x]=low[x]=++cnt;
stk[++top]=x,instk[x]=;
for(int i=head1[x];i;i=nxt1[i])
{
int y=ver1[i];
if(!dfn[y])
tarjan(y),
low[x]=min(low[x],low[y]);
else if(instk[y])
low[x]=min(low[x],dfn[y]);
}
if(low[x]==dfn[x])
{
int now=;tag++;
while(now!=x)
{
now=stk[top--];
instk[now]=;
val[tag]++;
belong[now]=tag;
}
}
}
void rebuild()
{
tot=;
for(int x=;x<=n;x++)
for(int i=head1[x];i;i=nxt1[i])
{
int y=ver1[i];
if(belong[x]!=belong[y])
add2(belong[x],belong[y]);
}
}
void dp()
{
int l=,r=;
for(int i=;i<=tag;i++)
{
if(!in[i]) stk[r++]=i;
f[i]=val[i],g[i]=;
}
while(l!=r)
{
int x=stk[l++];
for(int i=head2[x];i;i=nxt2[i])
{
int y=ver2[i]; in[y]--;
if(!in[y]) stk[r++]=y;
if(vis[y]==x) continue;
if(f[x]+val[y]>f[y])
{
f[y]=f[x]+val[y];
g[y]=g[x];
}
else if(f[x]+val[y]==f[y])
g[y]=(g[x]+g[y])%p;
vis[y]=x;
}
}
}
int main()
{
scanf("%d%d%d",&n,&m,&p);
for(int i=,x,y;i<=m;i++)
{
scanf("%d%d",&x,&y);
add1(x,y);
}
for(int i=;i<=n;i++) if(!dfn[i]) tarjan(i);
rebuild(); dp();
for(int i=;i<=tag;i++)
{
if(f[i]>maxn) maxn=f[i],ans=g[i];
else if(f[i]==maxn) ans+=g[i],ans%=p;
}
printf("%d\n%d\n",maxn,ans);
return ;
}

bzoj1093【ZJOI2007】最大半联通子图的更多相关文章

  1. bzoj1093 [ZJOI2007]最大半联通子图 缩点 + 拓扑序

    最大半联通子图对应缩点后的$DAG$上的最长链 复杂度$O(n + m)$ #include <cstdio> #include <cstring> #include < ...

  2. 【BZOJ1093】[ZJOI2007]最大半联通子图(Tarjan,动态规划)

    [BZOJ1093][ZJOI2007]最大半联通子图(Tarjan,动态规划) 题面 BZOJ 洛谷 洛谷的讨论里面有一个好看得多的题面 题解 显然强连通分量对于题目是没有任何影响的,直接缩点就好了 ...

  3. [bzoj 1093][ZJOI2007]最大半联通子图(强联通缩点+DP)

    题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1093 分析: 首先肯定是先把强联通全部缩成一个点,然后成了一个DAG 下面要知道一点: ...

  4. BZOJ1093 [ZJOI2007]最大半连通子图 【tarjan缩点 + DAG最长路计数】

    题目 一个有向图G=(V,E)称为半连通的(Semi-Connected),如果满足:?u,v∈V,满足u→v或v→u,即对于图中任意 两点u,v,存在一条u到v的有向路径或者从v到u的有向路径.若G ...

  5. BZOJ1093: [ZJOI2007]最大半连通子图(tarjan dp)

    题意 一个有向图G=(V,E)称为半连通的(Semi-Connected),如果满足:?u,v∈V,满足u→v或v→u,即对于图中任意两点u,v,存在一条u到v的有向路径或者从v到u的有向路径.若G' ...

  6. BZOJ1093 [ZJOI2007]最大半连通子图

    Description 一个有向图G=(V,E)称为半连通的(Semi-Connected),如果满足:?u,v∈V,满足u→v或v→u,即对于图中任意两点u,v,存在一条u到v的有向路径或者从v到u ...

  7. bzoj1093[ZJOI2007]最大半连通子图(tarjan+拓扑排序+dp)

    Description 一个有向图G=(V,E)称为半连通的(Semi-Connected),如果满足:?u,v∈V,满足u→v或v→u,即对于图中任意两点u,v,存在一条u到v的有向路径或者从v到u ...

  8. bzoj1093: [ZJOI2007]最大半连通子图 scc缩点+dag上dp

    一个有向图G=(V,E)称为半连通的(Semi-Connected),如果满足:?u,v∈V,满足u→v或v→u,即对于图中任意两点u,v,存在一条u到v的有向路径或者从v到u的有向路径.若G'=(V ...

  9. 【tarjan 拓扑排序 dp】bzoj1093: [ZJOI2007]最大半连通子图

    思维难度不大,关键考代码实现能力.一些细节还是很妙的. Description 一个有向图G=(V,E)称为半连通的(Semi-Connected),如果满足:?u,v∈V,满足u→v或v→u,即对于 ...

  10. BZOJ1093 ZJOI2007最大半连通子图(缩点+dp)

    发现所谓半连通子图就是缩点后的一条链之后就是个模板题了.注意缩点后的重边.写了1h+真是没什么救了. #include<iostream> #include<cstdio> # ...

随机推荐

  1. DongDong跳一跳

    题目连接:https://ac.nowcoder.com/acm/contest/904/C 题意很好理解,思路想歪了,本来一道很简单的题,写了好久没写出来. 思路就是找每一个高度最大值的时候就是找“ ...

  2. axiospost请求向后端提交数据

    Axios向后端提交数据容易接收不到原因是传参方式是request payload,参数格式是json,而并非用的是form传参,所以在后台用接收form数据的方式接收参数就接收不到了.post表单请 ...

  3. VM内存溢出

    平常开发时,有的人会运行的同时,会改代码,可能会导致VM内存溢出 Eclipse需要设置如下步骤: 1.点击Run>Run Configurations.. 2.定位到Tomcat(自己本地配置 ...

  4. python虚拟环境 virtualenv工具

    为了隔离各类环境,保证环境间不冲突,python中存在虚拟环境,可以在一个文件夹里生成相应的环境,防止与python自带环境冲突 首先我们下载virtualenv,若你未安装python,应到pyth ...

  5. nginx安装与部署

    1:安装工具包 wget.vim和gcc yum install -y wget yum install -y vim-enhanced yum install -y make cmake gcc g ...

  6. videojs的使用

    [官网]http://www.videojs.com/ videojs就提供了这样一套解决方案,他是一个兼容HTML5的视频播放工具,早期版本兼容所有浏览器,方法是:提供三个后缀名的视频,并在不支持h ...

  7. js跨域及解决办法

    1.什么是跨域 我们经常会在页面上使用ajax请求访问其他服务器的数据,此时,客户端会出现跨域问题. 跨域问题是由于javascript语言安全限制中的同源策略造成的. 简单来说,同源策略是指一段脚本 ...

  8. JZOJ 5818. 【NOIP提高A组模拟2018.8.15】 做运动

    5818. [NOIP提高A组模拟2018.8.15] 做运动 (File IO): input:running.in output:running.out Time Limits: 2000 ms  ...

  9. 数据分析处理库Pandas——概述

    导入Pandas库 创建DataFrame结构 读取.csv文件 titanic_train.csv文件:https://files.cnblogs.com/files/gloria-zhang/ti ...

  10. libevent 信号事件实现方式

    学会使用libevent,才能真正的掌握其是实现原理,我们先从一个简短的测试用例开始: #include <sys/types.h> #include <sys/stat.h> ...