图的邻接矩阵存储方式

2024-05-02 06:08
文章标签 方式 存储 邻接矩阵

本文主要是介绍图的邻接矩阵存储方式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

图的邻接矩阵的存储方式是用两个数组来表示图。一个一维数组存储图的顶点信息一个二维数组存储图中的边的信息。假设一维数组为vexs[maxvex],二维数组为arc[maxvex][maxvex],maxvex=100。

在无向图中:

  1. 若顶点vi与vj之间的权重为w则arc[i][j]=w;
  2. 若顶点vi与vj之间无连接则arc[i][j]=65535;
  3. 若顶点vi与vi之间则arc[i][j]=0。

由于是无向图则arc[i][j]=arc[j][i]。

在有向图中同上只不过arc[i][j]!=arc[j][i],要给arc[j][i]赋予自己的权值。

#ifndef Graph_H
#define Graph_H
#include<fstream>
#include<iostream>
#define MAXVEX 100
#define INFINITY 65535
typedef int VertexType;
typedef int EdgeType;
typedef int ShortPathTable[MAXVEX];
typedef int Pathmatirx[MAXVEX];
class Graph
{
public:Graph();~Graph();void CreateMGraph();
public:VertexType vexs[MAXVEX];EdgeType arc[MAXVEX][MAXVEX];int numVertexs, numEdge;
private:};
#endif // !Graph_H
#include"Graph.h"
using namespace std;
Graph::Graph()
{
}Graph::~Graph()
{
}
void Graph::CreateMGraph()
{int i, j, k, w;cout << "输入顶点数和边数" << endl;cin >> numVertexs >> numEdge;for ( i = 0; i < numVertexs; i++){vexs[i]=i;}ifstream infile;infile.open("inputdata.txt");for ( i = 0; i < numVertexs; i++){for (j = 0;j < numVertexs;j++){arc[i][j] = INFINITY;}}for ( k = 0; k < numEdge; k++){infile >> i >> j >> w;arc[i][j] = w;arc[j][i] = w;}infile.close();for (i = 0;i < numVertexs;i++){for (j = 0;j < numVertexs;j++){cout << arc[i][j] << " ";}cout << endl;}
}

代码中为无向图的邻接矩阵的存储,其中inputdata.txt存放着顶点与边的信息,读者可以自己设置。

这篇关于图的邻接矩阵存储方式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/953533

相关文章

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

Spring创建Bean的八种主要方式详解

《Spring创建Bean的八种主要方式详解》Spring(尤其是SpringBoot)提供了多种方式来让容器创建和管理Bean,@Component、@Configuration+@Bean、@En... 目录引言一、Spring 创建 Bean 的 8 种主要方式1. @Component 及其衍生注解

python中的显式声明类型参数使用方式

《python中的显式声明类型参数使用方式》文章探讨了Python3.10+版本中类型注解的使用,指出FastAPI官方示例强调显式声明参数类型,通过|操作符替代Union/Optional,可提升代... 目录背景python函数显式声明的类型汇总基本类型集合类型Optional and Union(py

Linux系统管理与进程任务管理方式

《Linux系统管理与进程任务管理方式》本文系统讲解Linux管理核心技能,涵盖引导流程、服务控制(Systemd与GRUB2)、进程管理(前台/后台运行、工具使用)、计划任务(at/cron)及常用... 目录引言一、linux系统引导过程与服务控制1.1 系统引导的五个关键阶段1.2 GRUB2的进化优

使用SpringBoot+InfluxDB实现高效数据存储与查询

《使用SpringBoot+InfluxDB实现高效数据存储与查询》InfluxDB是一个开源的时间序列数据库,特别适合处理带有时间戳的监控数据、指标数据等,下面详细介绍如何在SpringBoot项目... 目录1、项目介绍2、 InfluxDB 介绍3、Spring Boot 配置 InfluxDB4、I

IDEA与MyEclipse代码量统计方式

《IDEA与MyEclipse代码量统计方式》文章介绍在项目中不安装第三方工具统计代码行数的方法,分别说明MyEclipse通过正则搜索(排除空行和注释)及IDEA使用Statistic插件或调整搜索... 目录项目场景MyEclipse代码量统计IDEA代码量统计总结项目场景在项目中,有时候我们需要统计