求调
查看原帖
求调
1304032
Lwx112412楼主2025/2/8 10:14
#include <bits/stdc++.h>
#define int long long
const int INF=0x3f3f3f3f;

using namespace std;
int a[500][500];
int n,m;
int dis[500];
bool vis[500];
void bfs(){
	memset(vis,0,sizeof(vis));
	memset(dis,INF,sizeof(dis));
	queue<int>q;
	q.push(1);
	vis[1]=1;
	dis[1]=0;
	while(!q.empty()){
		int u=q.front();
		q.pop();
		vis[u]=0;
		for(int v=1;v<=n;v++){
			if(u==v){
				continue;
			}
			if(a[u][v]){
				if(dis[v]>dis[u]+1){
					dis[v]=dis[u]+1;
					if(!vis[v]){
						vis[v]=1;
						q.push(v);
					} 
				}
			}
		}
	}
}

signed main() {
	int u,v;
	cin>>n>>m;
	for(int i=1;i<=m;i++){
		cin>>u>>v;
		a[u][v]=a[v][u]=1;
	}
	if(a[1][n]==1){
		for(int i=1;i<=n;i++){
			for(int j=1;j<=n;j++){
				if(i==j){
					continue;
				}
				a[i][j]=1-a[i][j];
			}
		}
	}
	bfs();
	if(dis[n]==INF){
		cout<<"-1";
		return 0;
	}
	cout<<dis[n];
	return 0;
}

怎么不输出-1啊啊啊啊啊啊!!!!!!!

2025/2/8 10:14
加载中...