标签:mes 情况 set get ios 假设 getch show image
#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
typedef long long ll;
const int N=100000+100,M=N*3;
ll read() {
ll x=0,f=1;char c=getchar();
while(c<'0'||c>'9') {
if(c=='-') f=-1;
c=getchar();
}
while(c<='9'&&c>='0') {
x=x*10+c-'0';
c=getchar();
}
return x*f;
}
int n,fa[N],ans[3],head[N],ejs,col[N],ji[N];
struct node {
int nxt,v;
}e[M];
void add(int u,int v) {
e[++ejs].v=v;e[ejs].nxt=head[u];head[u]=ejs;
}
void init() {
ans[2]=ans[1]=0;
memset(head,0,sizeof(head));
ejs=0;
memset(col,-1,sizeof(col));
memset(ji,0,sizeof(ji));
memset(fa,0,sizeof(fa));
n=read();int m=read();
for(int i=1;i<=m;++i) {
int u=read(),v=read();
add(u,v);add(v,u);
}
}
int Jump(int u,int v) {//标记为奇环 并判断相交
for(;u!=v&&u;u = fa[u]) {
if(ji[u]) return 1;
ji[u] = 1;
}
return 0;
}
void dfs(int u) {
for(int i=head[u]; i;i=e[i].nxt) {
int v = e[i].v;
if(v == fa[u]) continue;
if(col[v] == -1) {
col[v] = col[u]^1;//二分图染色
fa[v] = u;
dfs(v);
}
else {
if(col[v] == col[u]) {
ans[1] = 1;
if(Jump(u,v)) ans[2] = 1;//如果两个奇环有相交部分,那么就有偶环
}
else ans[2] = 1;
}
}
}
void solve() {
for(int i=1;i<=n; ++i) {
if(col[i] == -1) {
col[i] = 0;
dfs(i);
}
}
if(ans[1]) puts("YES");
else puts("NO");
if(ans[2]) puts("YES");
else puts("NO");
}
int main() {
int t=read();
while(t--) {
init();
solve();
}
return 0;
}
标签:mes 情况 set get ios 假设 getch show image
原文地址:https://www.cnblogs.com/wxyww/p/9783663.html