图论简介[通俗易懂]

图论简介[通俗易懂]这里介绍图论(GraphTheory),图论是计算机科学中非常重要的一部分内容,甚至可以单独划分成为一个领域。很多人第一次接触到图论这个词,就觉得图论是研究和图画相关的内容。不过当大家真的去学习图

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

这里介绍图论(Graph Theory),图论是计算机科学中非常重要的一部分内容,甚至可以单独划分成为一个领域很多人第一次接触到图论这个词,就觉得图论是研究和图画相关的内容。

   

图论简介[通俗易懂]

     

不过当大家真的去学习图论时,可能大多数人都会失望一下子,因为图论实际上研究的是由顶点和边组成的一种数学模型,这种数学模型非常抽象,并且看起来也很枯燥。

   

图论简介[通俗易懂]

 

虽然图论看起来很枯燥,但是如果大家真正的深入研究下去,就会发现图论是一个非常酷的学科世界中很多的信息之间的联系,都可以使用图这种抽象的数学方式来进行表示,如下就是表示互联网之间关系的连接图。

   

图论简介[通俗易懂]

   

通过建造这样的模型,可以得出很多非常有意思的结论,进而实现更大的目标,创造出更酷的产品当然,要将一个图的模型,表示成如上图所示,其实很大程度上是数据可视化带来的收益从算法的角度来研究图,还是相对比较枯燥的。

如下,就是一张图:

   

图论简介[通俗易懂]

对于图这种数学模型来说,有两个非常重要的组成部分:(1)顶点(Vertex)  (2)边(Edge)  其中,顶点和顶点之间就是靠边连接起来的,顶点和边一起构成了一张图。

 

以图作为模型,来表示真实世界之间的关系,那么可以表示什么样的关系呢?从表面上看,这种形式好像很简单,也很枯燥,但是它的内涵却很丰富,如下:

(1)交通运输

最典型的莫过于交通运输,它可以使用图来表达,如:每个顶点可以是一个城市,每条边可以是城市之间的道路再扩展一下,每个顶点可以是一个航站楼,每条边可以是相应的航线,每个顶点可以是港口,每条边可以是相应的海运线甚至更宏观的,每个顶点可以是一个星球,每条边可以是星球之间宇宙飞船飞行的航线,亦或更微观的,每个顶点可以是城市中的一座楼,每条边可以是楼和楼之间的街道。如上,都是可以的,这是对于图来说,最直观的一种表示方式,但是,其实很多更抽象的数据关系,也可以用图来表示。

 

(2)社交网络

对于社交网络来说,每个顶点可以表示一个人,每条边可以表示

人与人之间的关系。这种关系可以是像 FaceBook 这种好友的关

系,也可以是像 Twitter 这种关注的关系。

 

(3)相似关系  

每个顶点可以表示一部电影,每条边可以表示两部电影之间的相似程度

   

(4)互联网

互联网,也可以用图来表示,每个顶点可以表示一个域名,每条边可以表示域名之间的跳转或 每个顶点可以表示一个页面,每条边可以表示页面之间的连接

 

(5)工作安排

在工作中的工作安排,也可以用图来表示,每个顶点可以是一个工作内容,每条边可以是两个工作内容之间的相关程度,或 先后执行的优先级顺序。

 

(6)脑区活动

像脑区活动的研究这样更复杂、更专业的领域,也经常用到图,每个顶点可以是一个脑区,每条边可以是脑区之间信息的传递。

 

(7)程序状态执行

在计算机程序中,程序状态的执行,也可以用图来表示,每个顶点可以表示一个程序状态,每条边可以表示从一种状态执行到另外一种状态。对于这种情况,最典型的一个应用就是自动机,包括制作专业的编译器,甚至是做一个游戏,都可能要设计一个自动机。在这种情况下,或多或少都会使用图论建模的方法。

 

图的分类

使用图可以表示这么多真实世界中不同事物之间的关系,那么在表示的过程中,图也会有一些区别,如下:(1)无向图(Undirected Graph)和有向图(Directed Graph)所谓无向图,即 边是没有方向的,如:在社交网络中,每个顶点表示一个人,人与人之间认识,就连接上一条边,而这个边是没有方向的。

   

图论简介[通俗易懂]

所谓有向图,即 边是有方向的,如:在自动机中,每个顶点表示一个事件,每条边表示从一个事件转移到另一个事件,并且这个转移是具有方向性的。

   

图论简介[通俗易懂]

显然,有向图由于其不对称性,所以在很多时候,有向图会涉及到一些相对比较难的算法。其实,无向图可以看做是一种特殊的有向图,如下: 两个顶点之间用一条没有方向的边连接在了一起。

图论简介[通俗易懂]

换个角度,可以将一条没有方向的边,换成是两条有方向的边

图论简介[通俗易懂]

所以说:无向图是一种特殊的有向图

(2)无权图(Unweighted Graph)和有权图(Weighted Graph) 所谓权,可以理解成就是一个数值,而无权和有权,即 连接顶点和顶点之间的边,有没有一个数值和它对应。对于无权图来说,如:在社交网络中,每个顶点表示一个人,每条边表示两个人之间是否认识,即 这条边只表示认识 或不认识的状态存在与否,而不需要有一个值和它联系。

   

图论简介[通俗易懂]

而对于有权图来说,如:在交通运输中,每个顶点表示一个地点,每条边表示地点之间的道路。在这种情况下,每条边可能有一个值来表示两个地点之间的距离,或运输费用。

   

图论简介[通俗易懂]

 

图的连通性

在之前举的例子里,图中的顶点和边全部都连接在了一起,但事实上,作为一个图来说,不一定图中的每一个顶点都要被边连接起来,这就涉及到了图的连通性。如下:

   

图论简介[通俗易懂]

如上所示,它可以是三个图,即 有三个部分,但也可以是一个模型中的一个图,只不过它不是完全连通的,其中有三个连通分量。
 

简单图 

简单图(Simple Graph),即 不含自环边和平行边的图

 

图论简介[通俗易懂]  

在图论中,存在两种相对比较特殊的边:(1)自环边(self-loop):一个顶点到这个顶点自身的边  (2)平行边(parallel-edges):两个顶点之间存在多条边相连接。无论是自环边还是平行边,在很多时候也是有意义的最典型的,如:对于交通运输来说,从 A 城市到 B 城市可能有不止一条路,可能有三条路,在这种情况下,平行边就非常有意义 但与此同时,自环边和平行边,会加大算法设计的难度,而且在很多情况下,我们真正关心的问题,其实是和自环边 或 平行边是无关的最典型的,如:要考察一张图的连通性,那么自环边和平行边都不会改变这张图的连通性。

所以,大多数情况下,讨论的都是简单图

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/166864.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • docker启动mysql镜像命令_ubuntu20修改ip命令

    docker启动mysql镜像命令_ubuntu20修改ip命令1、拷贝mysql离线包1.1、将mysql-57.gz安装文件拷贝到linux2、安装mysql2.1、进入mysql安装包目录2.2、加载mysql镜像dockerload-imysql-57.gz2.3、查看镜像dockerimages2.4、创建mysql容器启动mysql镜像,创建一个mysql容器dockerrun-d–namemysql-p3307:3306-eMYSQL_ROOT_PASSWORD=1234569e64d176cd

  • PLSQL来Oracle创建表空间和创建用户

    PLSQL来Oracle创建表空间和创建用户//创建临时表空间createtemporarytablespacetest_temptempfile’E:/oracle/product/10.2.0/oradata/testserver/test_temp01.dbf’size32mautoextendonnext32mmaxsize2048mextentmanagementlocal;

  • SQLPLUS登陆命令「建议收藏」

    一.SQLPLUS登陆命令:使用sqlplus:10G之前的版本登陆时需要加引号(单、双引号皆可)如:sqlplus"/assysdba"sqlplus-prelim/assysdba    从Oracle10g开始,sqlplus提供了一个参数选项-prelim,用这个参数,在系统已经hang的时候可以连接到SGA而不是数据库,也就…

  • awvs无法启动问题

    awvs无法启动问题awvs作为一个自动化漏扫工具,话说挺好用的,刚开始用的awvs11,用的还行,就是报告里报文啥的不好操作,然后去年下载了awvs13准备安装使用,结果,结果,试了n次,都是无法使用试了网上好多解决教程,重启服务等等,还是不行,那时候果断放弃了,今天突然想把awvs,burp和xray结合起来使用,就又开始安装折腾awvs14,试了三次,果不其然,不行突然发现我的计算机名字是中文,awvs14不支持计算机名为中文,啊,改改改。…

  • ideamaven仓库设置_搭建maven仓库

    ideamaven仓库设置_搭建maven仓库1、Maven下载在maven官网下载maven安装:http://maven.apache.org/download.cgi下载之后解压到安装路径:完成安装。2、Maven本地仓库配置在本地新建本地仓库文件夹,替代默认新建在系统盘的仓库地址,因为随着时间,仓库会越来越大,所以建议自己新建一个本地仓库:Maven远程库也是位于网络上的存储库。因为maven在获取需要的jar包时会首先从本地仓库获取,当本地仓库不存在需要的jar包时会从setting.xml的…

  • java事务回滚案例_java事务控制

    java事务回滚案例_java事务控制疑问,确实像往常一样在service上添加了注解 @Transactional,为什么查询数据库时还是发现有数据不一致的情况,想想肯定是事务没起作用,出现异常的时候数据没有回滚。于是就对相关代码进行了一番测试,结果发现一下踩进了两个坑,确实是事务未回滚导致的数据不一致。下面总结一下经验教训:Spring事务的管理操作方法编程式的事务管理实际应用中很少使用通过

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号