PAT1013. Battle Over Cities(邻接矩阵邻接表分别dfs)

Posted zeroArn

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PAT1013. Battle Over Cities(邻接矩阵邻接表分别dfs)相关的知识,希望对你有一定的参考价值。

//采用不同的图存储结构结构邻接矩阵、邻接表分别dfs,我想我是寂寞了吧,应该试试并查集,看见可以用并查集的就用dfs,bfs代替。。。。。。怕了并查集了

//邻接矩阵dfs

#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn=1001;
int g[maxn][maxn];
int n,tmp;
bool vis[maxn];
void dfs(int v)
{
vis[v]=true;
for(int i=1;i<=n;i++)
{
if(!vis[i]&&g[v][i]>0)dfs(i);
}
}
int dfstra()
{
int i;
fill(vis,vis+maxn,false);
int cnt=0;
for(i=1;i<=n;i++)
if(g[tmp][i]>0)g[tmp][i]=g[i][tmp]=-1;
for( i=1;i<=n;i++)
{
if(!vis[i]&&i!=tmp)
{
dfs(i);
cnt++;
}
}
for(i=1;i<=n;i++)
if(g[tmp][i]<0)g[tmp][i]=g[i][tmp]=1;
return cnt-1;
}
int main()
{
freopen("input.txt","r",stdin);
int i,j,m,k;
while(scanf("%d%d%d",&n,&m,&k)!=EOF)
{
int a,b;
fill(g[0],g[0]+maxn*maxn,0);
for(i=0;i<m;i++)
{
scanf("%d%d",&a,&b);
g[a][b]=g[b][a]=1;
}
for(i=0;i<k;i++)
{
scanf("%d",&tmp);
printf("%d\n",dfstra());
}
}
return 0;
}

//邻接表dfs

#include<cstdio>
#include<vector>
#include<algorithm>
using namespace std;
const int maxn=1001;
vector<int >g[maxn];
bool vis[maxn];
int n,cur;
void dfs(int v)
{
vis[v]=true;
for(int i=0;i<g[v].size();i++)
{
int t=g[v][i];
if(!vis[t]&&t!=cur)dfs(t);
}
}
int dfstra()
{
int i;
fill(vis,vis+maxn,false);
int cnt=0;
for( i=1;i<=n;i++)
{
if(!vis[i]&&i!=cur)
{
dfs(i);
cnt++;
}
}
return cnt-1;
}
int main()
{
freopen("input.txt","r",stdin);
int i,j,m,k;
while(scanf("%d%d%d",&n,&m,&k)!=EOF)
{
int a,b;
for(i=0;i<m;i++)
{
scanf("%d%d",&a,&b);
g[a].push_back(b);
g[b].push_back(a);
}
for(i=0;i<k;i++)
{
scanf("%d",&cur);
printf("%d\n",dfstra());
}
}
return 0;
}

以上是关于PAT1013. Battle Over Cities(邻接矩阵邻接表分别dfs)的主要内容,如果未能解决你的问题,请参考以下文章

PAT1013: Battle Over Cities

pat 1013 Battle Over Cities(25 分) (并查集)

PAT A1013 Battle Over Cities (25 分)

PAT Advanced 1013 Battle Over Cities (25分)

PAT Advanced Level 1013 Battle Over Cities (25)(25 分)

PAT 1013Battle Over Cities