图的遍历之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);
        }
    }
}
相关推荐
困死,根本不会几秒前
蓝桥杯 Python 备考全攻略:从入门到进阶的学习路线
笔记·python·学习·算法·蓝桥杯
油泼辣子多加6 分钟前
【ML】SVM算法原理
人工智能·算法·机器学习·支持向量机·数据挖掘
Irissgwe11 分钟前
二叉树进阶,map和set
数据结构·算法
郝学胜-神的一滴29 分钟前
深度学习入门基石:PyTorch张量核心技术全解析
人工智能·pytorch·python·深度学习·算法·机器学习
Frostnova丶36 分钟前
(10)LeetCode 560. 和为K的子数组
算法·leetcode·哈希算法
AI专业测评40 分钟前
2026年AI写作软件底层技术全景解析:长篇AI写网文的工程化实践与AI消痕算法基准测试
人工智能·算法·ai写作
2401_884563241 小时前
高性能日志库C++实现
开发语言·c++·算法
葳_人生_蕤1 小时前
hot100——226.翻转二叉树
算法
handler011 小时前
基础算法:BFS
开发语言·数据结构·c++·学习·算法·宽度优先
2401_879503411 小时前
C++中的状态模式实战
开发语言·c++·算法