Educoder数据结构实验 图结构试验 第4关:深度优先生成树


任务描述

本关任务:构造无向图的深度优先搜索树。

相关知识

实验目的

  1. 掌握图的基本概念;
  2. 掌握图的存储结构的设计与实现,基本运算的实现;
  3. 熟练掌握图的两种遍历算法、遍历生成树及遍历算法的应用。

实验任务

说明:为使实验程序简洁直观,下面的部分实验程序中的一些功能实现仍以调用库函数程序"graph.h"中的函数的形式给出,并假设该库函数中定义了图结构的类型、结构以及其他一些有关图、边、顶点等的基本操作和函数。

实验说明

图结构及其类型描述

在本头文件中,用自然数表示顶点号。所涉及到的图可以是无向图、有向图、带权图(即网络)等形式。在内部采用邻接表存储,但用户不必关心其具体的存储形式,因为有关的内容可通过头文件中所提供的函数获得。
图结构类型datagraph的描述如下:

struct  datagraph  
{        
   bool direct; //是否是有向的  
   bool flag; //表示这条边是否存在  
};  

构建图

为了使同学们不因为复杂的存储结构而分散精力,本实训使用图的邻接矩阵来存储图,也就是datagraph类型的二维数组,datagraph[i][j]表示顶点i到顶点j的边的信息。
如需了解图的邻接表存储结构,推荐一种比较方便的链式前向星存储结构,同学们可以去网上自行查阅相关知识。

编程要求

请在右侧编辑器的命名空间内填写相关代码,实现对给定的图G及出发点u,设计算法从u出发深度遍历图G,并构造出相应的生成树。
若题目有其它要求,应当将题目要求的结果在solve函数内通过返回或引用的形式传递参数。

数据说明:

  • 保证数据给出的图为简单无向联通图;
  • 保证数据给出的图的顶点数不超过 100;
  • G[u][v] 表示的是 u+1 和 v+1 的边。

测试说明

平台会对你编写的代码进行测试:

函数说明:  
vector<int> solve(vector<vector<datagraph> > & G, int u);  
参数 G 为图的邻接矩阵,参数 u 为给定的顶点  
返回一个一维数组表示从点 u 出发通过深度优先遍历依次访问的节点序列。

右侧数据框说明:  
测试输入:  
第一行三个整数 n,m 和 k,n 表示图的顶点总数,m 表示图的边或弧总数,k 表示图是否为有向图,若 k = 1 则表示图为有向图,若 k = 0 则表示图为无向图  
接下来 m 行每行两个整数 u 和 v,表示有一条边或弧 uv 存在  
最后一行一个整数 u,表示给定的顶点  
实际输出:  
输出你返回数组

结构体说明:  
struct  datagraph  
{        
   bool direct; //是否是有向的  
   bool flag; //表示这条边是否存在  
};

库函数详细可查看右侧头文件 "graph.h"  

头文件 “graph.h”

# include <bits/stdc++.h>
using namespace std;
namespace exa{

struct  datagraph
{
   bool direct; //是否是有向的
   bool flag; //表示这条边是否存在
};

int solve(vector<vector<datagraph> > & G);

static vector<vector<datagraph> >  load_graph() {
    int n, m, k, u, v;
    cin >> n >> m >> k;
    vector<datagraph> A;
    datagraph a;
    vector<vector<datagraph> > res;
    for (int i = 0; i < n; ++i) {
        res.push_back(A);
        for (int j = 0; j < n; ++j) {
            res[i].push_back(a);
        }
    }
    for (int i = 0; i < n; ++i) for (int j = 0; j < n; ++j) {
        res[i][j].flag = 0;
    }
    for (int i = 1; i <= m; ++i) {
        cin >> u >> v;
        --u; --v;
        if (k == 1) {
            res[u][v].direct = 1;
            res[u][v].flag = 1;
        }
        else {
            res[u][v].direct = res[v][u].direct = 0;
            res[u][v].flag = res[v][u].flag = 1;
        }
    }
    return res;
}
}

开始你的任务吧,祝你成功!😃

代码展示

#include "graph.h"   // 引用库函数文件  
namespace exa {     //请在命名空间内编写代码,否则后果自负
int vis[105];
void dfs(vector<vector<datagraph> > & G, int x, vector<int> & ans) {  
    if (vis[x] == 1) return ;  
    ans.push_back(x+1);  
    vis[x] = 1;  
    int n = (int)G.size();  
    for (int i = 0; i < n; ++i) if (G[x][i].flag == true) dfs(G, i, ans);  
}  
vector<int> solve(vector<vector<datagraph> > & G, int u) {  
    vector<int> ans;  
    --u;  
    dfs(G, u, ans);  
    return ans;  
}
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值