Educoder数据结构实验 图结构实验 第1关:求图中边或弧的数目


任务描述

本关任务:求给定图中的边(或弧)的数目。

相关知识

实验目的

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

实验任务

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

实验说明

图结构及其类型描述

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

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

构建图

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

编程要求

请在右侧编辑器的命名空间内填写相关代码,实现求给定图中的边(或弧)的数目。
若题目有其它要求,应当将题目要求的结果在solve函数内通过返回或引用的形式传递参数。

数据说明:

  • 保证数据给出的图为简单图;
  • 保证数据给出的图的顶点数不超过 100。

测试说明

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

函数说明:  
int solve(vector<vector<datagraph> > & G);  
参数 G 为图的邻接矩阵  
返回一个整数表示图中的边或弧的数目
右侧数据框说明:  
测试输入:  
第一行三个整数 n,m 和 k,n 表示图的顶点总数,m 表示图的边或弧总数,k 表示图是否为有向图,若 k = 1 则表示图为有向图,若 k = 0 则表示图为无向图  
接下来 m 行每行两个整数 u 和 v,表示有一条边或弧 uv 存在  
实际输出:  
你返回的值
结构体说明:  
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 solve(vector<vector<datagraph> > & G) {  
    int n = (int)G.size();  
    bool direct;  
    int ans = 0;  
    for (int i = 0; i < n; ++i) for (int j = 0; j < n; ++j) {  
        if (G[i][j].flag == true) {  
            direct = G[i][j].direct;  
            ++ans;  
        }  
    }  
    return direct == true ? ans : ans/2;  
}
}
  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值