首页 > Java > java教程 > 正文

表示加权图

王林
发布: 2024-09-06 06:07:02
原创
625 人浏览过

加权边可以存储在邻接列表中。

加权图有两种类型:顶点加权和边加权。在顶点加权图中,每个顶点都被分配一个权重。在边加权图中,每条边都被分配一个权重。在这两种类型中,边加权图有更多的应用。本章讨论边加权图。

加权图可以用与未加权图相同的方式表示,只不过您必须表示边上的权重。与未加权图一样,加权图中的顶点可以存储在数组中。本节介绍加权图中边的三种表示形式。

表示加权边:边数组

加权边可以使用二维数组来表示。例如,您可以使用下图(b)中的数组来存储下图(a)图中的所有边。

Representing Weighted Graphs

权重可以是任何类型:IntegerDoubleBigDecimal等。您可以使用 Object 类型的二维数组来表示加权边,如下所示:

对象[][]边缘= {
{new Integer(0), new Integer(1), new SomeTypeForWeight(2)},
{new Integer(0), new Integer(3), new SomeTypeForWeight(8)},
...
};

加权邻接矩阵

假设图有 n 个顶点。您可以使用二维 n * n 矩阵,例如 weights 来表示边上的权重。 weights[i][j] 表示边上的权重 (i, j)。如果顶点 ij 未连接,则 weights[i][j]null。例如,上图(a)中的权重可以使用邻接矩阵表示如下:

Representing Weighted Graphs

邻接表

表示边缘的另一种方法是将边缘定义为对象。 AbstractGraph.Edge 类被定义为表示 AbstractGraph.java 中的未加权边。对于加权边,我们定义 WeightedEdge 类,如下面的代码所示。

Representing Weighted Graphs

AbstractGraph.EdgeAbstractGraph 类中定义的内部类。它表示从顶点 uv 的边。 WeightedEdge 使用新属性 weight 扩展了 AbstractGraph.Edge

要创建 WeightedEdge 对象,请使用 new WeightedEdge(i, j, w),其中 w 是边上的权重 (i j)。通常您需要比较边的权重。因此,WeightedEdge 类实现了 Comparable 接口。

对于未加权图,我们使用邻接表来表示边。对于带权图,我们仍然使用邻接表,下图a中的图中顶点的邻接表可以表示为:

java.util.List[] list = new java.util.List[5];

Representing Weighted Graphs

Representing Weighted Graphs

list[i] 存储与顶点 i.

相邻的所有边

为了灵活性,我们将使用数组列表而不是固定大小的数组来表示 list,如下所示:

列表> list = new java.util.ArrayList();

以上是表示加权图的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:dev.to
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!