tarjan算法,枚举割点(注意此题无向图可能不连通),每个割点分割后最大块数+连通分量-1即可。开始老是TLE,后来比较了他人代码,只在vector<vector<int.>.>,用全局变量即可,用局部TLE。记住教训。

#include<iostream>  //600+MS/5000MS
#include<cstdio>
#include<vector> //用这个做链表,保存边,方便。
#include<cstring>
using namespace std;
int subnet[10001]; //割点i有subnet[i]+1个子网络
int dfn[10001];
int low[10001];
int visited[10001]; //标记访问
int time=0; //时间戳
int son=0; //DFS树根的孩子结点个数,割点判断条件之一
vector<vector<int> >v(10001); //做全局变量时时间降低,若做局部变量,虽然节省空间,用参数传递,时间增加TLE!!!!!!!!!
int min(int a,int b)
{
if(a<=b)return a;
return b;
}
void tarjan(int root,int u,int fa) //dfs
{
dfn[u]=low[u]=++time;
int daxiao=v[u].size();
for(int i=0;i<daxiao;i++) //遍历U的所有边
{
if(visited[v[u][i]]==0)
{
visited[v[u][i]]=1;
tarjan(root,v[u][i],u);
low[u]=min(low[u],low[v[u][i]]); //更新1
//回溯时判断
if(u==root) //割点判断条件1
{
son++;
}
else if(dfn[u]<=low[v[u][i]]) //非DFS树根 割点判断条件2
{
subnet[u]++; //每个U的子孩子对应一个块(u同时属于这些块)
}
}
else if(v[u][i]!=fa) //不必跟新父节点
{
low[u]=min(dfn[v[u][i]],low[u]); //更新2
}
}
}
int main()
{
int n,m;
while(~scanf("%d%d",&n,&m)&&(n||m))
{
if(m==0){printf("%d\n",n-1);continue;}
for(int i=0;i<n;i++)
{
dfn[i]=low[i]=visited[i]=subnet[i]=0;
v[i].clear();
} int a,b;
for(int i=0;i<m;i++)
{
scanf("%d%d",&a,&b);
v[a].push_back(b);
v[b].push_back(a);
}
time=0;son=0;
int countzitu=0; int count=0;
for(int i=0;i<n;i++)
if(dfn[i]==0)
{
visited[i]=1;
tarjan(i,i,-1);
countzitu++;
if(count<son)count=son;
son=0;
}
for(int i=0;i<n;i++)
if(subnet[i]+1>count)
{count=subnet[i]+1;}
printf("%d\n",count+countzitu-1);
}
return 0;
}

最新文章

  1. Git使用详细教程(二)
  2. [python]初试页面抓取——抓取沪深股市交易龙虎榜数据
  3. python - socket - client端指定ip和端口
  4. asp.net MVC中使用entity framework出现从 datetime2 数据类型到 datetime 数据类型的转换产生一个超出范围的值”的处理
  5. python 列表推导式
  6. 体验一下cygwin
  7. php javascript
  8. iOS 时钟动画
  9. hdu2089 不要62--经典数位DP
  10. 小tips:你不知道的 npm init
  11. 你不知道的JavaScript——this词法
  12. Jenkin配置执行远程shell命令
  13. Kaldi如何准备自己的数据
  14. python实现斐波那契数列
  15. 2019.03.18 连接my sql
  16. flask 使用宏渲染表单(包含错误信息)
  17. Unity3d代码及效率优化总结
  18. python3学习笔记(7)_listComprehensions-列表生成式
  19. Linux多线程--使用信号量同步线程【转】
  20. Node.js之Express四

热门文章

  1. ArrayList不同循环方式
  2. jsp &lt;%@ include %&gt; 例子
  3. IOS代码收集
  4. PMP项目管理学习笔记(7)——整合管理之指导和管理项目执行过程
  5. 诊断Java代码中常见的数据库性能热点问题应该这么做!
  6. 微信小程序开发系列七:微信小程序的页面跳转
  7. iOS开发内购全套图文教程
  8. 微信小程序---目录结构
  9. Elasticsearch document深度剖析
  10. luogu P1618 三连击(升级版)