Chinaunix首页 | 论坛 | 博客
  • 博客访问: 426736
  • 博文数量: 103
  • 博客积分: 5010
  • 博客等级: 大校
  • 技术积分: 971
  • 用 户 组: 普通用户
  • 注册时间: 2007-06-11 17:22
文章分类
文章存档

2008年(77)

2007年(26)

我的朋友

分类: C/C++

2007-12-19 23:35:28

static void dfs_traverse(algraph* g)
{
        int i;

        for(i = 0; i < g->nodes; i++){
                visited[i] = 0;
        }

        for(i = 0; i < g->nodes; i++){
                if(!visited[i]){
                        dfs(g, i);
                }
        }
        printf("\n");
}

static void dfs(algraph* g, int i)
{
        edgenode* p;

        visited[g->adjlist[i].vertex] = 1;
        printf("%d ", g->adjlist[i].vertex);

        p = g->adjlist[i].firstedge;
        for(p; p != NULL; p = p->next){
                if(!visited[p->adjvex]){
                        dfs(g, p->adjvex);
                }
        }
}

阅读(1511) | 评论(0) | 转发(0) |
0

上一篇:建立无向图的邻接表

下一篇:getchar函数

给主人留下些什么吧!~~