题目 1452: 蓝桥杯历届试题-网络寻路
我不理解为什么把邻接矩阵换成vector就能对了。
为啥注释掉的代码是不对的?
#include<iostream>
#include<cstring>
#include<algorithm>
#include<vector>
using namespace std;
typedef long long ll;
const int N = 1e4+10;
vector<int> G[N];
int vis[N];
int n,m;
int k = 0;
ll ans = 0;
void dfs(int s,int u,int t)
{
vis[u] = 1;
if(t==3) //如果到的不是最初的点
{
ans++;
return;
}
for(int i=0;i<G[u].size();i++)
{
if(!vis[G[u][i]])
{
dfs(s,G[u][i],t+1);
vis[G[u][i]] = 0;
}
else if(G[u][i]==s &&t==2) //如果到的是最初的点,且满足中间已经走了两个点
{
ans++;
}
}
}
int main()
{
cin>>n>>m;
for(int i=1;i<=m;i++)
{
int u,v;
scanf("%d%d",&u,&v);
G[u].push_back(v);
G[v].push_back(u);
}
for(int i=1;i<=n;i++)
{
memset(vis,0,sizeof(vis));
dfs(i,i,0);
}
cout<<ans;
}
/*
我不理解
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
typedef long long ll;
const int N = 1e4+10;
int a[N][N];
int vis[N];
int n,m;
int k = 0;
ll ans = 0;
void dfs(int s,int u,int t)
{
// printf("当前源节点为%d 当前结点为%d t=%d\n",s,u,t);
vis[u] = 1;
// for(int i=1;i<=n;i++) cout<<vis[i]<<" ";cout<<endl;
if(t==3)
{
// cout<<"!\n";
ans++;
return;
}
for(int i=1;i<=n;i++)
{
if(a[u][i] && (!vis[i]))
{
dfs(s,i,t+1);
vis[i] = 0;
}
else if(a[u][i] && i==s &&t==2)
{
// printf("%d到%d的环\n",i,i);
ans++;
}
}
}
int main()
{
cin>>n>>m;
for(int i=1;i<=m;i++)
{
int u,v;
scanf("%d%d",&u,&v);
a[u][v] = a[v][u] = 1;
}
for(int i=1;i<=n;i++)
{
memset(vis,0,sizeof(vis));
// vis[i] = 1;
dfs(i,i,0);
}
cout<<ans;
}
*/