原题链接:数据结构-有向无环图的拓扑排序
#include<iostream> #include<stack> using namespace std; int n,topo[100]={0},indegree[100]={0},a[100][100]; void FindInDegree() { for(int i=0;i<n;i++) for(int j=0;j<n;j++) if(a[i][j]) indegree[j]++; } bool TopoSort() { FindInDegree(); stack<int> s; int m=0; for(int i=0;i<n;i++) if(indegree[i]==0) s.push(i); while(!s.empty()) { int i=s.top(); topo[m++]=i; s.pop(); for(int j=0;j<n;j++) if(a[i][j]==1) { indegree[j]--; if(indegree[j]==0) s.push(j); } } if(m<n) return false; else return true; } int main() { cin>>n; for(int i=0;i<n;i++) for(int j=0;j<n;j++) cin>>a[i][j]; if(!TopoSort()) cout<<"ERROR"; else for(int i=0;i<n;i++) cout<<topo[i]<<" "; cout<<endl; return 0; }
0.0分
2 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复