POJ2367(拓扑排序裸题

跟風遠走 提交于 2019-12-05 09:16:32
 1 #include<iostream>
 2 #include<vector>
 3 #include<queue>
 4 using namespace std;
 5 typedef long long ll;
 6 const int N = 150;
 7 int in[N],n,r;
 8 vector<int>ans;
 9 vector<int>edge[N];
10 priority_queue<int,vector<int>,greater<int> >priq;
11 int main(){
12     ios::sync_with_stdio(0);
13     cin>>n;
14     for(int i = 1;i <= n;++i){
15         while(cin>>r){
16             if(r==0)break;
17             edge[i].push_back(r);in[r]++;
18         }
19     }
20     for(int i = 1;i <= n;++i)if(in[i]==0)priq.push(i);
21     while(!priq.empty()){
22         
23         int p = priq.top();priq.pop();
24         ans.push_back(p);
25         for(int j = 0;j < edge[p].size();++j){
26             int y = edge[p][j];in[y]--;
27             if(!in[y])priq.push(y);
28         }
29     }
30     for(int i = 0;i < n;++i){
31         if(i!=n-1)cout<<ans[i]<<" ";
32         else cout<<ans[i]<<endl;
33     }
34     return 0;
35 }

 

没什么好说的?自己练习拓排概念用的,目前理解的便是,找到入度为0的点加入队列,如果有字典序或者什么要求则用优先队列自定义排序写,然后删除加入队列的点所连接的边(减去其

指向的点的入度)然后当出现入度为0的点时再次加入队列,直到结束。如果最后队列中的点与所有点数目不一致,就说明有环或者别的,不能使用拓排

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!