解题思路:

注意事项:样例可以通过

参考代码:

#include<iostream>
#include<stack>
using namespace std;
#define ERROR -1
#define OK 1
#define MAX 51
int count;
int TopoloicalSort(int a[MAX][MAX],int n){
  stack<int>s;
  int indegree[n]={0};
  //求各顶点的入度情况
  for(int i=0;i<n;i++){
    for(int j=0;j<n;j++){
      if(a[i][j]!=0){
        indegree[j]++;
      }
    }
  }
  for(int i=0;i<n;i++){
    if(!indegree[i]){
      s.push(i);
    }
  }
  count=0;//对输出进行计数
  while(!s.empty()){
  int v=s.top();
    s.pop();
   cout<<v<<" ";
    ++count;
    for(int i=0;i<n;i++){
      if(a[v][i]!=0){
        indegree[i]=indegree[i]-1;
        if(!indegree[i]){
          s.push(i);
        }
        }
    }
  }
  //该有向图有回路
  if(count<n)
    return ERROR;
  else
    return OK;
}
int main(int argc, char const *argv[]) {
  int n;
  int a[MAX][MAX];
  cin>>n;
  for(int i=0;i<n;i++){
    for(int j=0;j<n;j++){
      cin>>a[i][j];
    }
  }
  TopoloicalSort(a,n);
  return 0;
}


点赞(0)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论