| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 4515 人关注过本帖
标题:有向图的拓扑排序
只看楼主 加入收藏
月下
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2008-7-2
收藏
 问题点数:0 回复次数:5 
有向图的拓扑排序
下面这段代码
//有向图的拓扑排序
#include <stdio.h>
#include <malloc.h>
#define MAXV 50
#define INF 32767
typedef int InfoType;
//邻接矩阵存储方法
typedef struct
{
    int no;
    InfoType info;
} VertexType;
typedef struct
{
    int edges[MAXV][MAXV];
    int n,e;
    VertexType vexs[MAXV];
} MGraph;
//邻接表存储方法
typedef struct ANode
{
    int adjvex;
    struct ANode *nextarc;
    InfoType info;
} ArcNode;
typedef struct
{
    VertexType data;
    int count;
    ArcNode *firstarc;
} VNode;
typedef VNode AdjList[MAXV];
typedef struct
{
    AdjList adjlist;
    int n,e;
} ALGraph;
//将邻接矩阵g转换成邻接表G
void MatToList(MGraph g,ALGraph *G)
{
    int i,j,n=g.n;
    ArcNode *p;
    G=(ALGraph *)malloc(sizeof(ALGraph));
    for(i=0;i<n;i++) G->adjlist[i].firstarc=NULL;
    for(i=0;i<n;i++)
    {
        for(j=n-1;j>=0;j--)
        {
            if(g.edges[i][j]!=INF&&g.edges[i][j]!=0)
            {
                p=(ArcNode *)malloc(sizeof(ArcNode));
                p->adjvex=j;
                p->nextarc=G->adjlist[i].firstarc;
                p->info=g.edges[i][j];
                G->adjlist[i].firstarc=p;
            }   
        }   
    }
    G->n=n;G->e=g.e;   
}     
//拓扑排序算法
void TopSort(ALGraph *G)
{
    int i,j;
    int St[MAXV],top=-1;
    ArcNode *p;
    for(i=0;i<G->n;i++) G->adjlist[i].count=0;
    for(i=0;i<G->n;i++)
    {
        p=G->adjlist[i].firstarc;
        while(p!=NULL)
        {
            G->adjlist[p->adjvex].count++;
            p=p->nextarc;
        }   
    }   
    for(i=0;i<G->n;i++)
    {
        if(G->adjlist[i].count==0)
        {
            top++;
            St[top]=i;
        }   
    }   
    while(top>-1)
    {
        i=St[top];top--;
        printf("%d ",i);
        p=G->adjlist[i].firstarc;
        while(p!=NULL)
        {
            j=p->adjvex;
            G->adjlist[j].count--;
            if(G->adjlist[j].count==0)
            {
                top++;
                St[top]=j;
            }   
            p=p->nextarc;
        }   
    }   
}   
     
//主函数
int main()
{
    int i,j,n;
    MGraph g;
    ALGraph *G;
    printf("请输入有向图的顶点个数:");//6
    while(scanf("%d",&n)!=EOF)
    {
        printf("请输入有向图的邻接矩阵:\n");
        /*
        0 1 32767 32767 32767 32767
        32767 0 1 32767 32767 32767
        32767 32767 0 1 32767 32767
        32767 32767 32767 0 32767 32767
        32767 1 32767 32767 0 1
        32767 32767 32767 1 32767 0
        */
        for(i=0;i<n;i++)
        {
            for(j=0;j<n;j++)
            {
                scanf("%d",&g.edges[i][j]);
            }
        }
        g.n=n;
        MatToList(g,G);
        printf("有向图的拓扑排序序列为:");
        TopSort(G);
        printf("\n请输入有向图的顶点个数:");
    }   
    return 0;
}        
运行之后就不知道怎么搞了啊。要向老师答辩.有谁能帮忙分析下怎么解释和运用这个程序啊!谢谢啦
搜索更多相关主题的帖子: 有向图 拓扑 int struct typedef 
2008-07-02 17:22
卧龙孔明
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:59
帖 子:3872
专家分:684
注 册:2006-10-13
收藏
得分:0 
拓补排序就是
每次从图中找出一个入度为0只有出度的点,然后移除该点,继续此过程
当找不到这样的点时,如果图中仍有剩余点,那么该有向图内有环,否则无环

My Blog: www.aiexp.info
虽然我的路是从这里开始的,但是这里不再是乐土.感谢曾经影响过,引导过,帮助过我的董凯,飞燕,leeco,starwing,Rockcarry,soft_wind等等等等.别了,BCCN.
2008-07-02 17:24
月下
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2008-7-2
收藏
得分:0 
[bo][un]卧龙孔明[/un] 在 2008-7-2 17:24 的发言:[/bo]

拓补排序就是
每次从图中找出一个入度为0只有出度的点,然后移除该点,继续此过程
当找不到这样的点时,如果图中仍有剩余点,那么该有向图内有环,否则无环

大侠能否运行下这个程序?然后看看如果解释这个程序?
2008-07-02 17:28
卧龙孔明
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:59
帖 子:3872
专家分:684
注 册:2006-10-13
收藏
得分:0 
......
我菜鸟一个.

仅仅解释了下拓补排序的主要思想和实现方法。具体的就不说了,程序也不运行了。我之前说的应该是正确的,但并不算严密。

My Blog: www.aiexp.info
虽然我的路是从这里开始的,但是这里不再是乐土.感谢曾经影响过,引导过,帮助过我的董凯,飞燕,leeco,starwing,Rockcarry,soft_wind等等等等.别了,BCCN.
2008-07-02 17:46
中学者
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:20
帖 子:3554
专家分:80
注 册:2007-9-14
收藏
得分:0 
另一个做法...用两个dfs~一个dfs确定完成时间....另外一个dfs根据完成时间的非升序排列遍历....

樱花大战,  有爱.
2008-07-02 18:19
monte
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2011-6-10
收藏
得分:0 
不错           
2011-11-14 14:31
快速回复:有向图的拓扑排序
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016550 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved