题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4857
----------------------------------------------------------------------------------------------------------------------------------------------------------
欢迎光临天资小屋:http://user.qzone.qq.com/593830943/main
----------------------------------------------------------------------------------------------------------------------------------------------------------
1 5 10 3 5 1 4 2 5 1 2 3 4 1 4 2 3 1 5 3 5 1 2
1 2 3 4 5
题目要求要求在满足约束条件的情况下,使小的序号尽力靠前。
坑点就在这里,小的序号尽量靠前并不是代表字典序,它要求多种情况时,先使1靠前(可能1只能在第2或第3位 那么就要使它在第2位),其次2,3。。而不是在当前情况下,该位最小是哪个就输出哪个
代码如下:
#include <cstdio> #include <iostream> #include <algorithm> #include <cstring> #include <queue> #include <vector> using namespace std; #define N 30017 int n, m; int i, j, k; int v[N],ans[N]; vector<int>P[N]; void init() { memset(ans,0,sizeof(ans)); memset(v,0,sizeof(v)); } void Topsort() { priority_queue<int>Q; int size, t; for(i = 1; i <= n; i++) { if(v[i] == 0) Q.push(i); } while(!Q.empty()) { t = Q.top(); Q.pop(); size = P[t].size(); for(i = 0; i < size; i++)//相关联的入度减1 { v[P[t][i]]--; if(v[P[t][i]] == 0) Q.push(P[t][i]); } ans[k++] = t; } } int main() { int T; int a, b; scanf("%d",&T); while(T--) { init(); scanf("%d%d",&n,&m); for(i = 1; i <= n; i++)//清空 { P[i].clear(); } for(i = 0; i < m; i++) { scanf("%d%d",&a,&b); v[a]++; P[b].push_back(a);//逆向建图,在b后面添加a } k = 0; Topsort(); for(i = n-1; i > 0; i--)//逆向输出 { printf("%d ",ans[i]); } printf("%d\n",ans[0]); } return 0; }
原文地址:http://blog.csdn.net/u012860063/article/details/38048097