You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

120 lines
2.0 KiB

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

///*
// * map06.cpp
// *
// * Created on: May 15, 2024
// * Author: 28032
// */
//// 1.先将ways数组全部初始化成0
//// 2.用DFS从1开始遍历图
//// ways[v] == 0时直接标记并以此再发起DFS
//// ways[v] == 1时说明在这一路的DFS中访问了一个结点两次有环
//// ways[v] == 2时说明前面的几路DFS中曾经访问过该节点有多路
//// 3.一次DFS还不行many和cycle的标记还在上游没有传到下游去
//// 所以这次DFS目的是将该节点的标记传给它的下一结点
//#include <iostream>
//#include <set>
//#include<string.h>
//
//using namespace std;
//int T,n,m;
//set<int> *g;
//bool *many,*cycle,*vis;
//int *ways;
//void dfs1(int v)
//{
// for(int p : g[v])
// {
// switch(ways[p])
// {
// case 0:
// ways[p] = 1;
// dfs1(p);
// break;
// case 1:
// cycle[p] = true;
// break;
// case 2:
// many[p] = true;
// break;
// }
// }
// ways[v] = 2;
//}
//
//void dfs2(int v)
//{
// vis[v] = true;
// if(many[v])
// for(int p : g[v])
// many[p] = true;
// if(cycle[v])
// for(int p : g[v])
// cycle[p] = true;
//
// for(int p : g[v])
// if(!vis[p]) dfs2(p);
//}
//
//void getRes(void)
//{
// for(int i = 1;i <= n;i++)
// {
// if(ways[i] == 0)
// continue;
// ways[i] = 1;
// if(many[i] && !cycle[i])
// ways[i] = 2;
// else if(cycle[i])
// ways[i] = -1;
// }
//}
//
//int main()
//{
// cin>>T;
//
// while(T--)
// {
// cin>>n>>m;
// g = new set<int>[n+1];
// many = new bool[n+1];
// cycle = new bool[n+1];
// vis = new bool[n+10];
// ways = new int[n+1];
// for(int i = 1;i <=n;i++)
// {
// many[i] = false;
// cycle[i] = false;
// vis[i] = false;
// ways[i] = 0;
// }
//
// for(int i = 1;i <= m;i++)
// {
// int a,b;
// cin>>a>>b;
// g[a].insert(b);
// }
//
// dfs1(1);
// dfs2(1);
// getRes();
//
// for(int i = 1;i <=n;i++)
// cout<<ways[i]<<" ";
// cout<<endl;
//
// delete[] ways;
// delete[] cycle;
// delete[] many;
// delete[] g;
// }
//
//
//
// return 0;
//}
//
//
//