图的相关种类

目录

数据类型

存储结构

邻接矩阵表示法

无向图

邻接矩阵表示

有向图

实现

邻接矩阵表示

存储结构

创建无向图

优点

缺点

邻接表法表示

表示无向图

表示有向图

存储结构

无向网

特点

十字链表与多重表

十字链表

存储结构

多重表

存储结构


数据类型

存储结构

邻接矩阵表示法

无向图

无向图的度=矩阵中非0元素个数和的一半 

邻接矩阵表示

有向图

因此,有向图的度为矩阵中非0元素个数总和

实现

邻接矩阵表示

存储结构

创建无向图

优点

缺点

邻接表法表示

表示无向图

表示有向图

示例

存储结构

先表示出所有边结点,再将边结点组成链表连接到各个对应顶点上。

示例

无向网

特点

十字链表与多重表

十字链表

为解决有向图求度不方便的问题

存储结构

firstin表示以data为弧头(终点,即指向data顶点-入)的边,firstout表示以data为弧尾(起点-出)的边。

tailvex表示弧的弧尾(起点)顶点序号,headvex表示弧的弧头(终点)顶点序号,

hlink指向下一个弧头相同的弧,tlink指向下一个弧尾相同的弧。

先列出所有弧,再连接到顶点。

多重表

存储结构

相关代码

#include <iostream>
using namespace std;
//图的存储//1.邻接矩阵存储:边数+顶点数+顶点表-一维+边表-二维
#define maxn 20
#define infi 33333333 
//类型定义 
typedef struct {char vexs[maxn];//顶点表 int arc[maxn][maxn];//边表 int vexnum,arcnum;//顶点数与边数 
}adjgraph;
//创建无向图
//1.输入边数与顶点数,初始边表-无穷 
//2.输入顶点,为顶点表赋值 
//3.输入边的顶点及权值,为边表赋值:需要先确定顶点的下标才能确定边 
int getvex(adjgraph *g,char v){for(int i=1;i<=g->vexnum;i++)if(g->vexs[i]==v) return i;return 0;
}
//后期实现!!!! 
//void print(adjgraph *g){
//	for(int i=1;i<=g->vexnum;i++)
//		if(g->vexs[i]==v) return i;
//} 
void create(adjgraph *g){char vex1,vex2;//存储边的顶点 int weigh;//存储边的权值 int  v1,v2;//存储边的下标 cout<<"输入顶点数及边数:"<<endl;cin>>g->vexnum>>g->arcnum;for(int i=1;i<=g->vexnum;i++){//初始边表 for(int j=1;j<=g->arcnum;j++){g->arc[i][j]=infi;} }for(int i=1;i<=g->vexnum;i++){//存储顶点信息 cout<<"请输入第"<<i<<"个顶点信息:\n";cin>>g->vexs[i];}for(int j=1;j<=g->arcnum;j++){//存储边表信息 cout<<"请输入第"<<j<<"条边的顶点信息:\n";cin>>vex1>>vex2;cout<<"请输入第"<<j<<"条边的权值:\n";cin>>weigh;v1=getvex(g,vex1);v2=getvex(g,vex2);g->arc[v1][v2]=weigh;//单向g->arc[v2][v1]=weigh;//双向-无向图 }
}//2.邻接表表示:顶点表+顶点数+边数 
//顶点表:顶点信息+第一条边结点
//边结点:顶点编号+边权+下一条边
int getvex2(adjlist &g,char v){for(int i=1;i<=g.vnum;i++)if(g.vex[i].vex==v) return i;return 0;
}
typedef struct acrnode{//边结点 int adjacr;//记录邻接顶点编号-弧尾 int weigh;//权值 acrnode *next;//有相同弧头顶点的下一个边结点 
}acrnode; 
typedef struct vnode{//顶点类型 char vex;acrnode *first;
}vnode; 
typedef struct {//邻接表 int vnum,acrnum;vnode vex[maxn];//顶点表 
}adjlist;
void create(adjlist &g){char v1,v2;int  vex1,vex2;acrnode n,m; //1.输入顶点数、边数cin>>g.vnum>>g.acrnum; //2.初始邻接表:输入顶点,初始顶点表头指针为空for(int i=1;i<=g.vnum;i++){cin>>g.vex[i].vex;g.vex[i].first=NULL;}//3.输入边顶点,构造边结点,记录弧头与弧尾顶点,头插边表for(int i=1;i<=g.acrnum;i++){cin>>v1>>v2;vex1=getvex2(g,v1);//弧尾 vex2=getvex2(g,v2);//弧头n=new acrnode;//构造边结点//记录边v1->v2; 并插入到顶点v1的边表中 n->adjacr=vex2;//存储邻接v1的顶点v2的编号 n->next=g.vex[vex1].first;//下一个边结点存储原来v1顶点的第一个边结点g.vex[vex1].first=n;//更新v1顶点的第一条边为n,实现插入 //记录边v2->v1:新边结点结构-左边记录邻接指点编号  权值   右边记录具有同样以v2为弧尾的下一条边结点 m=new acrnode;m->adjacr=vex1;//记录邻接v2的顶点v1的编号m->next=g.vex[vex2].first;//下一个边结点存储v2指向的第一个边结点 g.vex[vex2].first=m;//更新顶点v2的第一条边结点,实现插入 } 
}//3.十字链表表示:弧结点+顶点结点==>顶点表+弧数+顶点数-解决有向图找出入度的问题
//弧结点 
typedef struct acrnode{int tailvex,headvex;//弧头+弧尾编号struct acrnode *tailacr,*headacr;//分别具有相同弧头和弧尾的下一条弧结点 
}arcnode;
typedef struct vexnode{char data;//顶点信息 acrnode *tail,*head;//以顶点为弧尾或为弧头的弧结点 
}vexnode; 
typedef struct node{int vnum,acrnum;vexnode v[maxn];
};//4.多重表:顶点结点+边结点==>顶点表+边数+顶点数-解决无向图重复存边的问题
typedef struct acrnode{int tailvex,headvex;//组成边结点的两顶点编号 struct acrnode *tailacr,*headacr;//与边结点顶点相同的边结点 int weigh;//边的权重 
}; 
//顶点结点:顶点信息+指向第一条边的指针 
typedef struct vexnode{char data;acrnode *first;//第一条边结点 
}; 
typedef struct node{int vnum,vacr;vexnode v[maxn];//顶点表 
}; 
int main(){adjgraph g;create(&g);return 0;
} 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/24116.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SharePoint:智能内容管理,释放数据价值

在Microsoft 365的庞大生态系统中&#xff0c;SharePoint常常被忽视&#xff0c;但它却是整个平台的核心。SharePoint不仅承载着OneDrive、Teams、Power Platform等所有Microsoft 365产品的内容存储&#xff0c;更是企业协作和内容管理的基石。助AI技术的加持&#xff0c;Share…

VBA实战(Excel)(4):实用功能整理

1.后台打开Excel 用于查数据&#xff0c;工作中要打开多个表获取数据再关闭的场景&#xff0c;利用此函数可以将excel表格作为后台数据库查询&#xff0c;快速实现客户要求&#xff0c;缺点是运行效率不够高。 Sub openexcel(exl_name As String)If Dir(addr, 16) Empty Then…

遗址博物馆ar互动展示软件提供丰富的趣味化体验

在自然博物馆的每一个角落&#xff0c;都隐藏着大自然的奥秘与魅力。为了让每一位参观者都能深入体验、探索这些奥秘&#xff0c;我们引入了前沿的AR技术&#xff0c;为您带来一场前所未有的沉浸式自然之旅。 步入博物馆&#xff0c;您手中的AR相机将成为您的更佳向导。自然博物…

Python语言在金融领域的应用探索

Python语言在金融领域的应用探索 Python语言&#xff0c;以其简洁、易读和强大的功能库&#xff0c;近年来在金融领域崭露头角。它不仅为数据分析师、量化分析师和交易员提供了强大的工具&#xff0c;还在风险管理、投资组合优化等方面发挥了重要作用。本文将深入剖析Python语…

剪画小程序:图片去除文字,我用它只要10秒!

Hello&#xff0c;大家好呀&#xff01;我是不会画画的小画~ 图片上的文字该如何去除&#xff1f; 在工作或者学习中&#xff0c;我们常常需要处理一些图片文件&#xff0c;比如扫描的文件、 电子文档等。有时候&#xff0c;图片上可能会有文字&#xff0c;这时候需要将图片…

解决富文本中抖音视频无法播放的问题——403

问题 富文本中的抖音视频无法播放&#xff0c;资源状态码是403禁止访问打开控制台&#xff0c;可以看到在项目中打开&#xff0c;数据请求的请求头多了一个Referer: http://localhost:3000/而复制链接在新窗口直接打开&#xff0c;请求头中并不会携带Referer 解决方案 在ind…

在 Windows 7 中安装 .NET Framework 时遇到错误:无法建立到信任根颁发机构的证书链

当全新安装 Windows 7 SP1 后&#xff0c;在未安装任何补丁&#xff0c;也未进行联网的状态下&#xff0c;安装 .NET Framework 4.6/4.7 或更高的版本时&#xff0c; 应该会遇到错误提示&#xff1a;无法建立到信任根颁发机构的证书链。 解决方法 1.下载证书 地址&#xff1…

Selenium三种等待方式的使用!

UI自动化测试&#xff0c;大多都是通过定位页面元素来模拟实际的生产场景操作。但在编写自动化测试脚本中&#xff0c;经常出现元素定位不到的情况&#xff0c;究其原因&#xff0c;无非两种情况&#xff1a;1、有frame&#xff1b;2、没有设置等待。 因为代码运行速度和浏览器…

QT creator c动态链接库的创建与调用

QT creator c动态链接库的创建与调用 QT5.15.2 1.创建dll项目 确保两类型选择正确 2.选择MinGW 64-bit 3.点击完成 pro文件参考&#xff1a; QT - guiTEMPLATE lib DEFINES QT_DLL_DEMO_LIBRARYCONFIG c17# You can make your code fail to compile if it uses deprecat…

[原创][Delphi多线程]使用TMonitor和TQueue配合实现TThreadedQueue的经典使用案例.

[简介] 常用网名: 猪头三 出生日期: 1981.XX.XX QQ: 643439947 个人网站: 80x86汇编小站 https://www.x86asm.org 编程生涯: 2001年~至今[共22年] 职业生涯: 20年 开发语言: C/C、80x86ASM、PHP、Perl、Objective-C、Object Pascal、C#、Python 开发工具: Visual Studio、Delph…

gpt4free软件的 g4f gui 网页速度非常慢的问题解决

问题&#xff1a;g4f gui启动网页很难连上 gpt4free是一个为大众提供的Openai等大模型API调用服务的软件&#xff0c;但是在装好启动g4f gui&#xff0c;使用8080端口连接后&#xff0c;发现网页一直在执行&#xff0c;半天还没好。 怀疑是网页里面的一些js加载有问题。 通过…

MC服务器怎么搭建

MC服务器怎么搭建?随着《我的世界》&#xff08;Minecraft&#xff0c;简称MC&#xff09;的火爆&#xff0c;越来越多的玩家和社区开始搭建自己的MC服务器&#xff0c;与朋友共享创造的乐趣。但搭建一台稳定、高效的MC服务器并不是一件容易的事。今天&#xff0c;我们就来聊聊…

vb.net学习总结

基本语法 Read()函数可充当暂停进行使用 要转换成什么类型就在前面加上C类型&#xff08;&#xff09;即可 取模运算不是%而是Mod 不等于不是!而是<> 在Unicode编码中小写字母比大写字母靠后 Asc&#xff08;char ch&#xff09;取ASC码 使用Is/Like与其他的字符串拼…

【高考】互联网时代,问题何去何从?

随着互联网的普及、人工智能的应用&#xff0c;越来越多的问题能很快得到答案。那么&#xff0c;我们的问题是否会越来越少&#xff1f; 以上材料引发了你怎样的联想和思考&#xff1f;请写一篇文章。 要求&#xff1a;选准角度&#xff0c;确定立意&#xff0c;明确文体&#…

App UI 风格创新无限

App UI 风格创新无限

Java-exam

Java 一卷 T1 /* 编写一个Java程序&#xff0c;求1!2!…10!的值&#xff0c;程序文件命名为“FactoriesSum.java”。*/ package Test.A基础语法.T1;public class FactoriesSum {public static void main(String[] args) {int sum 0,num1;for (int i1;i<10;i){numnum*i;s…

快速制作技术插图,高效管理零部件手册

在当前的制造业和工程领域中&#xff0c;技术插图对于产品设计、制造、维修和市场营销等环节具有至关重要的作用。然而&#xff0c;传统的插图制作方式往往依赖于人工绘制或使用较为复杂的软件&#xff0c;效率低下&#xff0c;而且容易出错。 由于CAD技术的广泛应用&#xff…

备份树莓派系统的多种方法,构建镜像

在我们使用树莓派进行学习或者搭建实验环境时经常会把系统玩坏&#xff0c;辛苦配置的开发环境又得重新配置&#xff1b;或者更新某一软件后发现新版本和某些组件不兼容&#xff0c;又无法降级。这个时候我们会想将系统在稳定时进行备份&#xff0c;在系统出现问题后可以很方便…

网络编程——套接字缓存(buffer)满会丢失数据吗

套接字缓冲区已满并不意味着数据丢失&#xff0c;但它可能会导致发送和接收数据的操作阻塞或失败&#xff0c;从而间接导致数据丢失或延迟。 解释 发送端缓冲区已满&#xff1a; 当发送端的套接字缓冲区已满时&#xff0c;send 或 write 操作会阻塞&#xff0c;直到有足够的空…

爬虫工具yt-dlp

yt-dlp是youtube-dlp的一个fork&#xff0c;youtube-dlp曾经也较为活跃&#xff0c;但后来被众多网站屏蔽&#xff0c;于是大家转而在其基础上开发yt-dlp。yt-dlp的github项目地址为&#xff1a;GitHub - yt-dlp/yt-dlp: A feature-rich command-line audio/video downloaderA …