图的遍历之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);
        }
    }
}
相关推荐
sheeta19982 小时前
LeetCode 每日一题笔记 日期:2026.05.08 题目:3629. 素数跳跃最小次数
笔记·算法·leetcode
叼烟扛炮2 小时前
C++ 知识点08 类与对象
开发语言·c++·算法·类和对象
米粒12 小时前
力扣算法刷题 Day 63 Bellman_ford 算法
数据库·算法·leetcode
IT大白鼠8 小时前
AIGC性能的关键瓶颈:算力、数据、算法三者如何互相制约?
算法·aigc
白雪茫茫9 小时前
监督学习、半监督学习、无监督学习算法详解
python·学习·算法·ai
FengyunSky9 小时前
浅析 空间频率响应 SFR 计算
算法
树下水月9 小时前
PHP 一种改良版的雪花算法
算法·php·dreamweaver
一只数据集10 小时前
全尺寸人形机器人灵巧手力觉触觉数据集-2908条ROSbag数据覆盖14大应用场景深度解析
大数据·人工智能·算法·机器人
罗西的思考11 小时前
【GUI-Agent】阿里通义MAI-UI 代码阅读(2)--- 实现
人工智能·算法·机器学习
刀法如飞12 小时前
TypeScript 数组去重的 20 种实现方式,哪一种你还不知道?
前端·javascript·算法