图论其实不难入门

对于有多年的编程经验的开发者来说,图的概念并不陌生。许多顶级公司在技术面试中测试对图论的理解。 其实,开发者无需处理高级问题即可利用这些概念。要想明白这一点,我们可以先回顾一下为什么图是流行的数据结构以及如何在代码中实现它们。

关系模型

无论编码经验如何,开发者都应该对数组和字典的数据类型有所了解。 这些集合是大多数语言中使用的标准概念,在呈现基于列表的内容时效果很好:

☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜

图论其实不难入门 

大多数情况下,列表是从数据库或基于 REST 的查询中显示信息的完美解决方案。 然而,有时列表需要提供存在相互关联的上下文的记录。此时,将数据组织为图表变得方便。

对于图表,主要目标不是列出信息(尽管这一点可以做到),而是定义对象之间的关系。为什么定义对象之间的关系会有用?不妨看看以下几个例子。

图论其实不难入门 

一个有两个顶点和一个边的无向图

(1)地图应用程序

如果在技术面试中被问到,你将如何组织数据,以便重新创建地图服务(如 Apple 或 Google Maps)?除了在数据库中提供所有已知道路的列表外,你创建的模型还需要根据一天中的时间、交通和单行道等因素确定到达目的地的最佳方式。要使这大量的数据有效,您需要知道一条道路与模型中的所有其他街道之间的关系。

(2)社交媒体

一个社交媒体的价值,通常由用户关注或关注用户的人数来衡量。像Twitter这样的网络平台可以让用户与任何人联系,并接收他们的最新动态,从而吸引了大量用户。

 LinkedIn模型更为详细,因为除非接收者接受用户的连接请求,否则用户无法将某人添加到该用户的网络中。在这种情况下,LinkedIn连接代表双向关系。顺着这个思路,用户也可以搜索其人际网络中是否有人与其想要的工作机会相关联。在这种情况下,“网络”可能意味着直接或间接的联系。这样一个强大的模型不仅仅是基于一个简单的列表,它还包含了确定所有配置文件如何关联的智慧。

图形组件

现在我们已经了解了图在日常应用程序中的使用方式,下面我们来介绍图的组成部分。

图中的节点称为顶点。虽然可以将图构建为单个顶点,但包含多个顶点的模型可以更好地代表现实世界的应用。

图中的对象通过称为边的连接相互关联。

根据您的需求,顶点可以通过边连接到一个或多个物体上,也可以创建一个没有边的顶点。

最后,与堆栈或队列等其他标准结构不同,图通常没有指定的起点或终点。 以下是一些示例图形配置:

图论其实不难入门 

一个有两个顶点和一个边的无向图

图论其实不难入门 

一个有两个顶点和一个边的无向图

图论其实不难入门 

一个有两个顶点和一个边的无向图

有向与无向

在无向图中,源顶点和目标之间的连接是相等的。这些模型代表双向连接——类似于地图应用程序中的双向街道。

要定义单向连接,我们可以使用线和箭头将模型更新为有向图:

图论其实不难入门 

三个顶点和三个边的有向图

连通性水平

有时,我们必须表示图中顶点之间的连接程度。这种技术在量化节点之间的距离、时间或严重性时效果很好。权值通常与一条边相关,是一个用于跟踪的比较变量。 。

图论其实不难入门 

三个顶点和三个边的有向图,其中边加权

 

图顶点

有了对图论的基本了解后,让我们看看如何在代码中复制这些模型。下面我们创建了一个支持自定义通用对象 (T) 的顶点。 tvalue变量表示该类型保存的数据,包括单个字符串、int或自定义类型(例如,街道名称或社交媒体资料)。

另外,注意要让我们的类型符合流行的Equatable协议 (Swift)。这可以让我们在需要时比较特定顶点实例是否相等。

public class Vertex  : Equatable {

​var tvalue: T?
​var neighbors = Array<Edge>()
​let uuid = UUID()

​public init(with name: T) {
self.tvalue = name
​}

​//equatable conformance
​public static func == (lhs: Vertex, rhs: Vertex) -> Bool {
return lhs.uuid == rhs.uuid
​}
}

 

邻接表

邻接表表示与其他顶点的连接。如前面所述,每个顶点可以连接到一个或多个邻接的点。 这种关系列表有时称为“邻接表”,可以用来解决许多高级问题。

var neighbors = Array<Edge>()

图边

在创建顶点时,我们添加了一个邻接属性来存储自定义边类型的数组。 下面一条边为后续的相邻顶点及其潜在的边的权值提供参考。

public class Edge  {

​var neighbor: Vertex
​var weight: Int

​init() {
weight = 0
self.neighbor = Vertex()
​}
}

构建画布

有了顶点和边对象,我们现在可以将它们添加到中央存储结构中,我们称之为图形画布。尽管我们的画布在技术上是一个数组,但我们的目标是将集合可视化为一组关系。 借助addVertex 函数,我们可以向画布添加单个通用顶点,同时addEdge方法可提供边所需的参考信息。

最后,我们的代码假设图是有向的,因为边(仅)被添加到源顶点邻接表中。

public class Graph  {

​var canvas: Array<Vertex>

public init() {
canvas = Array()
​}

​//add vertex to graph canvas
​public func addVertex(element: Vertex) {
canvas.append(element)
​}
/add edge
​public func addEdge(source: Vertex, neighbor: Vertex, weight: Int) {

//create a new edge
let newEdge = Edge()

//connect source vertex to neighboring edge
newEdge.neighbor = neighbor
newEdge.weight = weight

source.neighbors.append(newEdge)
​}
}

总之,我们介绍了图的有关知识,并了解了如何使用它们来表示对象之间的关系,还回顾了配置图的几种方法以及用于描述不同模型的组件。

定义了模型后,我们就为更高级的功能奠定了基础,包括图形导航和遍历算法,如广度优先搜索。

译者介绍

康少京,51CTO社区编辑,目前从事通讯类行业,底层驱动开发岗位,研究过数据结构,Python,现对操作系统和数据库等相关领域感兴趣。

 原文标题:The complete beginner’s guide to graph theory,作者:Wayne Bishop

链接:

https://stackoverflow.blog/2022/05/26/the-complete-beginners-guide-to-graph-theory/

以上就是图论其实不难入门的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/564170.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
《红果短剧》提现到支付宝方法
上一篇 2025年11月10日 02:29:19
win11怎么查看系统启动和关机历史记录_Windows 11启动与关机日志查看
下一篇 2025年11月10日 02:29:26

相关推荐

  • JavaScript 中使用多个 querySelector 更新页面元素

    本文旨在讲解如何在 JavaScript 的 if 语句中使用多个 querySelector 来更新不同的页面元素,并提供示例代码和注意事项,帮助开发者理解并应用此技术。通过该方法,可以根据特定条件动态修改页面内容,提升用户体验。 使用 querySelector 在 if 语句中更新多个元素 在…

    2026年5月10日
    100
  • 控制HTML Canvas颜色空间输出24位深度TIFF图像

    本教程详细介绍了如何在web前端环境中,特别是结合`html2canvas`和`canvas-to-tiff`库时,通过明确设置html canvas的颜色空间为`srgb`,从而确保输出24位深度的tiff图像。文章将提供具体的javascript代码示例,并解释其原理,帮助开发者解决canvas…

    2026年5月10日
    100
  • HTML中如何实现MathML

    答案是利用HTML5原生支持MathML,只需将MathML代码嵌入标签即可,现代浏览器能直接渲染,无需插件;通过CSS可美化公式样式,如字体、颜色、间距等,提升显示效果;对于老旧浏览器,推荐使用MathJax作为兼容方案,支持LaTeX输入并渲染为高质量公式,兼顾可访问性与跨浏览器兼容性。 在HT…

    2026年5月10日
    000
  • p5.js图像像素化与阈值处理:loadPixels()函数深度解析与性能优化

    本教程深入探讨p5.js中`loadpixels()`函数在图像像素化与阈值处理中的应用。我们将重点讲解如何优化`loadpixels()`的调用时机以提升性能,正确计算图像亮度,并构建清晰有效的条件阈值逻辑。文章还涵盖了避免变量命名冲突、选择合适的绘图函数等关键实践,旨在帮助开发者高效、准确地实现…

    2026年5月10日
    000
  • JavaScript图形可视化与Canvas编程

    Canvas是JavaScript图形可视化核心,通过获取2D上下文实现绘图;可绘制矩形、路径、圆弧并设置样式,结合requestAnimationFrame实现动态柱状图动画。 JavaScript 图形可视化在现代网页开发中扮演着重要角色,尤其适合需要动态展示数据的场景,比如仪表盘、图表、动画和…

    2026年5月10日
    000
  • HTML Canvas动画残影消除:实现动态元素无痕移动

    本文旨在解决HTML Canvas动画中元素移动时产生的残影问题。通过在每个动画帧开始时清空并重绘Canvas背景,可以有效消除元素留下的“轨迹”,实现平滑、无痕的动态效果。文章将详细介绍背景重绘的实现方法,并提供代码示例,同时探讨如何利用半透明背景创建渐隐残影的进阶技巧。 理解Canvas动画中的…

    2026年5月10日
    000
  • HTML结构错误解析与W3C验证器指南

    本文旨在深入解析常见的html结构错误,特别是涉及` `、“和` `元素的不当使用,这些错误常导致w3c验证器报错。我们将详细阐述这些元素的正确语义和放置规则,解释隐式闭合机制如何引发验证问题,并通过实际代码示例展示如何构建符合标准、易于维护的html文档,从而提升网页的兼容性和可访问性…

    2026年5月10日
    000
  • html如何制作水印_HTML水印(文字/图片)添加与设置方法

    使用CSS和HTML可实现网页水印,方法包括:一、通过background-image与data URI嵌入斜向文字水印;二、利用伪元素结合transform旋转生成叠加文字层;三、插入img标签或背景图设置固定位置图片水印;四、用Canvas绘制多行斜纹并转Base64作背景;五、通过禁用右键、屏…

    2026年5月10日
    100
  • Canvas 环形进度条:实现无动画即时显示百分比的教程

    本教程将指导您如何使用html canvas和javascript创建并即时显示一个环形进度条,而无需任何动画过渡。我们将通过调整javascript代码中的关键参数,使得进度条在加载时直接显示目标百分比,并提供优化方案以避免不必要的定时器开销,确保高效且直接的视觉反馈。 在Web开发中,进度条是常…

    2026年5月10日
    000
  • HTML5画布动画:制作简单动画的代码实现指南

    答案:使用HTML5 Canvas API制作动画需先创建canvas元素并获取2D上下文,接着绘制基本图形,通过requestAnimationFrame实现循环更新位置与重绘,结合速度变量和边界检测控制运动,最后用对象数组管理多个动画元素。 如果您尝试在网页中创建动态视觉效果,但不知道如何开始,…

    2026年5月10日
    000
  • 如何自学HTML5_HTML5自学技巧【指南】

    掌握HTML5需系统学规范、用平台实操、拆解开源项目、做功能练习、测无障碍性。重点包括语义标签、表单控件、localStorage、Canvas及ARIA等,结合W3C文档、CodePen、GitHub与校验工具实践。 如果您希望掌握HTML5的基础知识并独立构建网页,可以从理解其核心语法和语义化结…

    2026年5月10日
    000
  • 怎样使用JavaScript进行图像处理与滤镜效果实现?

    JavaScript通过Canvas API实现图像处理,先加载图像并绘制到canvas,再用getImageData获取像素数据,遍历修改RGB值实现灰度、反色、亮度调节等滤镜,最后用putImageData将结果渲染回canvas。 JavaScript 可以通过 HTML5 的 Canvas …

    2026年5月10日
    000
  • HTML5Canvas怎么画图_HTML5Canvas元素绘制图形的基本方法与实例

    Canvas通过JavaScript绘制图形,需先创建画布并获取2D上下文;使用fillRect、strokeRect绘矩形,arc绘圆,lineTo连线,结合fillStyle等设样式;示例绘制了黄色笑脸,包含眼嘴,体现其在图形与动画中的灵活性。 HTML5 中的 Canvas 元素提供了一个通过…

    2026年5月10日
    000
  • 利用CSS实现高性能无缝循环背景动画的实践指南

    本教程深入探讨了javascript canvas中实现无缝循环背景动画时可能遇到的常见逻辑问题,例如图像位置重置失效导致动画中断。针对这些挑战,我们提出并详细讲解了如何利用css的`background-repeat`、`transform`和`@keyframes`属性,构建一个高性能、平滑且易…

    2026年5月10日
    000
  • PHP图片怎么滤镜_PHP图片滤镜效果实现及图像处理库。

    可通过GD库和ImageMagick实现多种PHP图片滤镜。一、灰度滤镜:启用GD后,用imagecreatefromjpeg()加载图像,imagefilter($image, IMG_FILTER_GRAYSCALE)转灰度,保存并释放资源。二、复古滤镜:加载图像后叠加色彩偏移imagefilt…

    2026年5月10日
    000
  • p5.js 中函数首次调用耗时较长的原因分析与优化

    在 p5.js 中,尤其是在使用 WEBGL 渲染器时,函数首次调用往往比后续调用耗时更长。这是由于图像纹理的初始化和上传过程导致的。首次调用时,需要分配显存、将图像数据复制到显存,并进行着色器编译等操作,这些操作会显著增加耗时。后续调用则可以直接使用缓存的纹理,从而大大提高效率。本文将深入探讨这一…

    2026年5月10日
    000
  • 使用ThreeJS在Canvas中实现动态图像效果并与DOM同步

    本文探讨了如何在网页中利用html `canvas>` 元素,结合threejs库,实现高级动态图像效果并与常规html dom元素完美同步。针对将图像渲染到canvas而非直接使用html “ 标签的挑战,我们揭示了threejs多元素渲染的核心机制,即通过动态调整渲染器的视口和裁剪区域,…

    2026年5月10日
    000
  • typescript用来干嘛_typescript的作用

    TypeScript 是一种用于构建大型复杂应用程序的开源编程语言,它扩展了 JavaScript 的功能,具有以下作用:类型系统:编译时检查类型错误,提高代码可靠性。面向对象编程特性:支持类、接口、抽象类,增强代码组织性和维护性。模块系统:分解程序为可重用模块,提升可维护性和可扩展性。全面的类型推…

    2026年5月10日
    000
  • JavaScript中Base64图片到ImageData数组的转换指南

    本文详细介绍了在javascript中如何将base64编码的图片字符串转换为可用于像素级操作的imagedata数组。通过利用html canvas元素和image对象,教程将逐步演示从加载base64图片、绘制到canvas,最终提取imagedata的过程,并提供完整的代码示例及注意事项,帮助…

    2026年5月10日
    000
  • html5如何录视频_HTML5录制视频流API使用指南【录制】

    可直接在网页中捕获并录制用户摄像头视频流:先用getUserMedia获取媒体流并预览,再通过MediaRecorder API录制为WebM格式,最后合并Blob导出下载;若不支持则回退至Canvas逐帧捕获合成。 如果您希望在网页中直接捕获用户的摄像头视频流并进行录制,则可以利用HTML5提供的…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信