一、题目概述
建立有向图,判断给定的序列是否为一个拓扑排序序列。
二、思路
迭代给定序列,若当前顶点入度非零, 则不是拓扑序列,否则将所有出边邻接顶点入度减一。
三、代码
#include <cstdio>
#include <vector>
using namespace std;
int main()
{
int N, M, K;
scanf("%d %d", &N, &M);
vector<int> G[N + 1], indegree(N + 1, 0), temp, ans;
for( int i = 0, v1, v2; i < M; ++i )
{
scanf("%d %d", &v1, &v2);
G[v1].push_back(v2);
++indegree[v2];
}
scanf("%d", &K);
for( int i = 0; i < K; ++i )
{
temp = indegree;
int flag = 1;
for( int j = 0, v; j < N; ++j )
{
scanf("%d", &v);
if( temp[v] )
flag = 0;
for( int k = 0; k < G[v].size(); ++k )
--temp[ G[v][k] ];
}
if( !flag )
ans.push_back(i);
}
for( int i = 0; i < ans.size(); ++i )
printf("%s%d", i ? " ":"", ans[i]);
}