图的遍历之DFS邻接矩阵法

本题要求实现一个函数,对给定的用邻接矩阵存储的无向无权图,以及一个顶点的编号v,打印以v为起点的一个深度优先搜索序列。

当搜索路径不唯一时,总是选取编号较小的邻接点。

本题保证输入的数据(顶点数量、起点的编号等)均合法。

函数接口定义:

复制代码
void DFS(struct Graph *g, int v)

其中 g 是图结构体指针,v 是起点编号。图结构体定义如下:

复制代码
#define MaxVertexNum 20  // 最大顶点数
struct Graph{
    int v;  // 顶点数量
    int adj[MaxVertexNum][MaxVertexNum]; //邻接矩阵
}

裁判测试程序样例:

复制代码
#include <stdio.h>
#include <stdlib.h>
/** 实际的测试程序中,
 ** MaxVertexNum可能不是20,
 ** 但一定是合法的、不会引发内存错误 
 **/
#define MaxVertexNum 20  
struct Graph{
    int v;  // 顶点数量
    int adj[MaxVertexNum][MaxVertexNum];  //邻接矩阵
};
int visited[MaxVertexNum];  //顶点的访问标记
void DFS(struct Graph *g, int v);  //本题要求实现的函数原型
struct Graph* CreateGraph(){    // 创建图
    int v;
    scanf("%d",&v);
    struct Graph* g;
    g = malloc(sizeof(struct Graph));
    if(!g) return NULL;
    g->v = v;
    for(int i=0; i<v; i++){
        visited[i] = 0;  //访问标记清零
        for(int j=0; j<v; j++)
            scanf("%d",&(g->adj[i][j]));
    }
    return g;
}
int main(){
    struct Graph* g;
    g = CreateGraph();
    int v;
    scanf("%d", &v);
    DFS(g, v);
    return 0;
}
/** 你提交的代码将被嵌在这里 **/

输入样例:

对于图片中的图以及样例测试程序的输入方式(8个顶点的邻接矩阵,从1号顶点出发):

复制代码
8
0 1 1 0 0 0 0 1
1 0 0 0 1 0 0 0
1 0 0 0 1 0 0 0
0 0 0 0 0 1 0 0
0 1 1 0 0 0 0 0
0 0 0 1 0 0 0 0
0 0 0 0 0 0 0 0
1 0 0 0 0 0 0 0
1

输出样例:

注意,总是选取编号小的邻接点

复制代码
1
0
2
4
7

实现代码(邻接矩阵)

复制代码
void DFS(struct Graph *g, int v)
{
    int w;
    printf("%d\n",v);
    visited[v]=1;
    for(int i=0;i<g->v;i++)
    {
        if((g->adj[v][i]!=0)&&(!visited[i]))
        {
            DFS(g,i);
        }
    }
}
相关推荐
我是苏苏1 小时前
C#高级:程序查询写法性能优化提升策略(附带Gzip算法示例)
开发语言·算法·c#
sali-tec2 小时前
C# 基于halcon的视觉工作流-章56-彩图转云图
人工智能·算法·计算机视觉·c#
黑岚樱梦6 小时前
代码随想录打卡day23:435.无重叠区间
算法
Kuo-Teng6 小时前
Leetcode438. 找到字符串中所有字母异位词
java·算法·leetcode
gihigo19987 小时前
MATLAB使用遗传算法解决车间资源分配动态调度问题
算法·matlab
墨染点香7 小时前
LeetCode 刷题【138. 随机链表的复制】
算法·leetcode·链表
却道天凉_好个秋7 小时前
目标检测算法与原理(一):迁移学习
算法·目标检测·迁移学习
兮山与8 小时前
算法24.0
算法
晓北斗NorSnow8 小时前
机器学习核心算法与学习资源解析
学习·算法·机器学习