小垃圾的跟班


私信TA

用户名:1298743454

访问量:12196

签 名:

等  级
排  名 1806
经  验 2626
参赛次数 0
文章发表 23
年  龄 0
在职情况 学生
学  校 陕西科技大学
专  业

  自我简介:

解题思路:

注意事项:样例可以通过

参考代码:

#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分

5 人评分

  评论区

  • «
  • »