”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 图表和应用

图表和应用

发布于2024-08-24
浏览:730

许多现实世界的问题可以使用图算法来解决。图对于建模和解决现实问题很有用。例如,找到两个城市之间的最少航班数量的问题可以使用图来建模,其中顶点代表城市,边代表两个相邻城市之间的航班,如下图所示。求最小联程航班数的问题
两个城市之间的问题简化为寻找图中两个顶点之间的最短路径。

Graphs and Applications

图问题的研究被称为图论。图论由 Leonhard Euler 于 1736 年创立,当时他引入图术语来解决著名的柯尼斯堡七桥问题。普鲁士柯尼斯堡市(现俄罗斯加里宁格勒)被普雷格尔河分开。河上有两个岛屿。城市和岛屿由七座桥梁连接,如下图(a)所示。问题是,一个人可以步行,每座桥只过一次,然后回到起点吗?欧拉证明这是不可能的。

Graphs and Applications

为了建立证明,欧拉首先通过消除所有街道来抽象柯尼斯堡城市地图,生成如上图 (a) 所示的草图。接下来,他将每个陆地块替换为一个点,称为顶点节点,并将每座桥替换为一条线,称为,如图所示上图(b)。这种具有顶点和边的结构称为 .

看图,我们问是否存在一条从任意顶点出发,恰好遍历所有边一次,并返回到起始顶点的路径。欧拉证明,要存在这样的路径,每个顶点必须具有偶数条边。因此,柯尼斯堡七桥问题无解。

图问题通常使用算法来解决。图算法在计算机科学、数学、生物学、工程学、经济学、遗传学和社会科学等各个领域都有许多应用。

基本图形术语

图由顶点和连接顶点的边组成。本章不假设您具备任何图论或离散数学的先验知识。我们使用简单明了的术语来定义图表。

Graphs and Applications

什么是图表?图是一种数学结构,表示现实世界中实体之间的关系。例如,上图代表城市之间的航班,下图(b)代表陆地之间的桥梁。

Graphs and Applications

图由一组非空顶点(也称为节点或点)和一组连接顶点的边组成。为了方便起见,我们将图定义为 G = (V, E),其中 V 表示一组顶点,E 表示一组边。例如下图中的V和E如下:

Graphs and Applications

V = {"西雅图", "旧金山", "洛杉矶",
“丹佛”、“堪萨斯城”、“芝加哥”、“波士顿”、“纽约”、
“亚特兰大”、“迈阿密”、“达拉斯”、“休斯顿”};

E = {{"西雅图", "旧金山"},{"西雅图", "芝加哥"},
{“西雅图”,“丹佛”},{“旧金山”,“丹佛”},
...
};

图可以是有向的,也可以是无向的。在有向图中,每条边都有一个方向,这表明您可以通过边从一个顶点移动到另一个顶点。您可以使用有向图来建模父/子关系,其中从顶点 A 到 B 的边表示 A 是 B 的父项。下图 (a) 显示了有向图。

Graphs and Applications

无向图中,您可以在顶点之间双向移动。下图是无向图。

Graphs and Applications

边可以加权也可以不加权。例如,您可以为上图中图表中的每条边分配一个权重,以指示两个城市之间的飞行时间。

图中的两个顶点被称为相邻如果它们由同一条边连接。类似地,如果两条边连接到同一顶点,则称它们是相邻。图中连接两个顶点的边被称为与两个顶点关联。顶点的是与其相关的边的数量。

两个顶点如果相邻,则称为邻居。类似地,如果两条边相邻,则称为 邻居

A 循环是将顶点链接到自身的边。如果两个顶点由两条或多条边连接,这些边称为平行边简单图是没有任何环或平行边的图。在完全图中,每两对顶点都是相连的,如下图(b)所示。

Graphs and Applications

如果图中任意两个顶点之间存在路径,则该图是连通的。图G的子图是一个图,其顶点集是G的子集,边集是G的子集。例如,上图(c)中的图是上图(b)中的子图。

假设该图是连通且无向的。 循环是一条从某个顶点开始并在同一顶点结束的闭合路径。如果连通图没有环,则它是。图G的生成树是G的连通子图,并且该子图是包含G中所有顶点的树。

版本声明 本文转载于:https://dev.to/paulike/graphs-and-applications-54lo?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何使用Regex在PHP中有效地提取括号内的文本
    如何使用Regex在PHP中有效地提取括号内的文本
    php:在括号内提取文本在处理括号内的文本时,找到最有效的解决方案是必不可少的。一种方法是利用PHP的字符串操作函数,如下所示: 作为替代 $ text ='忽略除此之外的一切(text)'; preg_match('#((。 &&& [Regex使用模式来搜索特...
    编程 发布于2025-03-09
  • 大批
    大批
    [2 数组是对象,因此它们在JS中也具有方法。 切片(开始):在新数组中提取部分数组,而无需突变原始数组。 令ARR = ['a','b','c','d','e']; // USECASE:提取直到索引作...
    编程 发布于2025-03-09
  • 可以在纯CS中将多个粘性元素彼此堆叠在一起吗?
    可以在纯CS中将多个粘性元素彼此堆叠在一起吗?
    [2这里: https://webthemez.com/demo/sticky-multi-header-scroll/index.html </main> <section> { display:grid; grid-template-...
    编程 发布于2025-03-09
  • 如何在Java字符串中有效替换多个子字符串?
    如何在Java字符串中有效替换多个子字符串?
    在java 中有效地替换多个substring,需要在需要替换一个字符串中的多个substring的情况下,很容易求助于重复应用字符串的刺激力量。 However, this can be inefficient for large strings or when working with nu...
    编程 发布于2025-03-09
  • 为什么使用Firefox后退按钮时JavaScript执行停止?
    为什么使用Firefox后退按钮时JavaScript执行停止?
    导航历史记录问题:JavaScript使用Firefox Back Back 此行为是由浏览器缓存JavaScript资源引起的。要解决此问题并确保在后续页面访问中执行脚本,Firefox用户应设置一个空功能。 警报'); }; alert('inline Alert')...
    编程 发布于2025-03-09
  • 如何使用PHP从XML文件中有效地检索属性值?
    如何使用PHP从XML文件中有效地检索属性值?
    从php PHP陷入困境。使用simplexmlelement :: attributes()函数提供了简单的解决方案。此函数可访问对XML元素作为关联数组的属性: - > attributes()为$ attributeName => $ attributeValue){ echo ...
    编程 发布于2025-03-09
  • Java是否允许多种返回类型:仔细研究通用方法?
    Java是否允许多种返回类型:仔细研究通用方法?
    在Java中的多个返回类型:一种误解类型:在Java编程中揭示,在Java编程中,Peculiar方法签名可能会出现,可能会出现,使开发人员陷入困境,使开发人员陷入困境。 getResult(string s); ,其中foo是自定义类。该方法声明似乎拥有两种返回类型:列表和E。但这确实是如此吗...
    编程 发布于2025-03-09
  • HTML格式标签
    HTML格式标签
    HTML 格式化元素 **HTML Formatting is a process of formatting text for better look and feel. HTML provides us ability to format text without us...
    编程 发布于2025-03-09
  • 我可以将加密从McRypt迁移到OpenSSL,并使用OpenSSL迁移MCRYPT加密数据?
    我可以将加密从McRypt迁移到OpenSSL,并使用OpenSSL迁移MCRYPT加密数据?
    将我的加密库从mcrypt升级到openssl 问题:是否可以将我的加密库从McRypt升级到OpenSSL?如果是这样,如何?答案:是的,可以将您的Encryption库从McRypt升级到OpenSSL。可以使用openssl。附加说明: [openssl_decrypt()函数要求iv参...
    编程 发布于2025-03-09
  • 如何从PHP中的数组中提取随机元素?
    如何从PHP中的数组中提取随机元素?
    从阵列中的随机选择,可以轻松从数组中获取随机项目。考虑以下数组:; 从此数组中检索一个随机项目,利用array_rand( array_rand()函数从数组返回一个随机键。通过将$项目数组索引使用此键,我们可以从数组中访问一个随机元素。这种方法为选择随机项目提供了一种直接且可靠的方法。
    编程 发布于2025-03-09
  • 如何使用不同数量列的联合数据库表?
    如何使用不同数量列的联合数据库表?
    合并列数不同的表 当尝试合并列数不同的数据库表时,可能会遇到挑战。一种直接的方法是在列数较少的表中,为缺失的列追加空值。 例如,考虑两个表,表 A 和表 B,其中表 A 的列数多于表 B。为了合并这些表,同时处理表 B 中缺失的列,请按照以下步骤操作: 确定表 B 中缺失的列,并将它们添加到表的末...
    编程 发布于2025-03-09
  • 为什么Microsoft Visual C ++无法正确实现两台模板的实例?
    为什么Microsoft Visual C ++无法正确实现两台模板的实例?
    The Mystery of "Broken" Two-Phase Template Instantiation in Microsoft Visual C Problem Statement:Users commonly express concerns that Micro...
    编程 发布于2025-03-09
  • 对象拟合:IE和Edge中的封面失败,如何修复?
    对象拟合:IE和Edge中的封面失败,如何修复?
    解决此问题,我们采用了一个巧妙的CSS解决方案来解决问题:左:50%; 高度:auto; 宽度:100%; //对于水平块 ,使用绝对定位将图像定位在中心,以object-fit:object-fit:cover in IE和edge消除了问题。现在,图像将按比例扩展,保持所需的效果而不会失真。...
    编程 发布于2025-03-09
  • 如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    从python import codecs import codecs import codecs 导入 text = codecs.decode('这狗\ u0001f602'.encode('utf-8'),'utf-8') 印刷(文字)#带有...
    编程 发布于2025-03-09
  • \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    答案: 在大多数现代编译器中,while(1)和(1)和(;;)之间没有性能差异。编译器: perl: 1 输入 - > 2 2 NextState(Main 2 -E:1)V-> 3 9 Leaveloop VK/2-> A 3 toterloop(next-> 8 last-> 9 ...
    编程 发布于2025-03-09

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3