码迷,mamicode.com
首页 > 编程语言 > 详细

POJ2367(拓扑排序裸题

时间:2019-11-23 18:36:37      阅读:78      评论:0      收藏:0      [点我收藏+]

标签:理解   int   自己   删除   bre   字典序   ++   def   定义排序   

 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的点时再次加入队列,直到结束。如果最后队列中的点与所有点数目不一致,就说明有环或者别的,不能使用拓排

POJ2367(拓扑排序裸题

标签:理解   int   自己   删除   bre   字典序   ++   def   定义排序   

原文地址:https://www.cnblogs.com/h404nofound/p/11918640.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!