拓扑排序

这里写图片描述

#include "iostream"
#include "stack"
#include "vector"
#include "string.h"
#define min(a, b) a < b ? a : b
using namespace std;

const int MAX_V = 100;
int visit[MAX_V];   //1表示已访问过,0表示未访问,-1表示正在访问
vector<int> G[MAX_V];
int V;
int cmp[MAX_V];   //拓扑排序顶点标号
int t;

void addEdge(int from, int to)
{
    G[from].push_back(to);
}

bool dfs(int v)
{
    visit[v] = -1;
    for(int i=0; i<G[v].size(); i++)
    {
        int u = G[v][i];
        if(visit[u] == -1)  //存在有向环
            return false;
        if(!visit[u] && !dfs(u))
            return false;
    }
    visit[v] = 1;
    cmp[--t] = v;
    return true;
}

bool toposort()
{
    t = V;
    memset(visit, 0, sizeof(visit));
    for(int i=1; i<=V; i++)
        if(!visit[i])
            if(!dfs(i))
                return false;
    return true;
}

int main()
{
    V = 4;
    addEdge(1, 2);
    addEdge(1, 3);
    addEdge(2, 4);
    addEdge(3, 4);

    if(!toposort())
        cout << "不存在拓扑排序!";
    else
    {
        cout << "拓扑排序为:" << endl;
        for(int i=0; i<V; i++)
            cout << cmp[i] << " ";
    }
    cout << endl;
    return 0;
}

这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值