BFS和DFS下的拓扑排序

      DAG是一种有向无环图,可以用来表示各种事务执行的先后顺序,而拓扑排序的作用就是找到恰当的工作顺序,使得对于所有有向边,都保证顶点u出现在顶点v之前。具体的拓扑排序的形象解释我这里就不多废话了,下面直接附上两种搜索形式下的拓扑排序:

    1.广度优先搜索实现的拓扑排序:

#include
#include
#include
using namespace std;
#define Max 10000
int N;
bool visited[Max];
vector G[Max];
int indeg[Max];
list out;
void bfs(int x)
{
	queue q;
	q.push(x);
	visited[x]=true;
	while(!q.empty())
	{
		int u=q.front();q.pop();
		out.push_back(u);
		for(int i=0;i::iterator it=out.begin();it!=out.end();it++)
	{
		cout<<(*it)<<" ";
	}
}
int main()
{
	int start,end,M;
	cin>>N>>M;

	for(int i=0;i>start>>end;
		G[start].push_back(end);
		indeg[end]++;
	}

    topologicalSort();

	return 0;
}

2.深度优先搜索实现的拓扑排序:

#include
#include
#include
using namespace std;
#define Max 10000
int N;
bool visited[Max];
vector G[Max];
list out;
void dfs(int u)
{
	cout<::iterator it=out.begin();it!=out.end();it++)
	{
		cout<<(*it)<<" ";
	}
}
int main()
{
	int start,end,M;
	cin>>N>>M;

	for(int i=0;i>start>>end;
		G[start].push_back(end);
	}

    topologicalSort();

	return 0;
}

    对于拓扑排序,大家要知道的是,对于同一个DAG,其拓扑排序的结果可能不止一种,这里的广度和深度在确定了相同情况下先输出小编号的顶点或者大编号的顶点,所以只会输出一种结果,具体的对于求解所有的拓扑排序的结果,我之后会找个时间学习,并附上代码.


PS:这三月份以来,事情就特别多,首先本创结题,其次是准备江苏省计算机三级,准备了一个星期,才发现考试真的是水,心碎~之后我还是会坚持写博客~


你可能感兴趣的:(算法,挑战程序设计竞赛)