java带权连通图上最小权边,连通图最小生成树的算法及实现

连通图的最小生成树

生成树定义:

无向连通图G的极小连通子图,称为它的生成树。(n个顶点,n-1条边)

考虑一下下面这个图

addc1dc112a17eb35be1e9269388de4e.png

上图是一个完全图,它的生成树不是唯一的,我们列出最特殊的两种情况

738866fab873e70689c38296eafb700b.png

21692cac0ae7fa91107b0fbf6861dfa9.png

上面2个图都是第一个完全图的生成树,但是2者是完全不同的。

按照深度优先遍历生成的生成树,称为深度优先生成树

按照广度优先遍历生成的生成树,称为广度优先生成树

非连通图的生成森林,概念比较简单,无非就是非连通图的极大连通子图和生成树的概念叠加

fcfb9cce7c908f339cc167f77017a1db.png

最小生成树

图G是带权的无向连通图,生成树上个边权值之和称为生成树的代价,代价最小的生成树称为最小生成树。

最小生成树的生成算法

Prim算法

现有连通图G=(V, E),其最小连通图TG=(TV, TE)。

初始状态下:V = {V0, V1, V2 ... Vn}; TV = {}

从V当中任选一顶点,插入TV,V = {V0, V1, V2 ... Vn}; TV = {V0}

找连接TV和V-TV这两个集合的权值最小的边,插入TE,并把该边2顶点当中原本不属于TV的顶点加入TV;

重复上一步骤

知道V = TV

下面是java实现,首先我们需要修改一下之前的生成图的代码,我们生成了一棵7个顶点的完全图,每一条边的权值是100以内的随机数。

Graph graph = new Graph();

String nodeNames[] = {"aaa", "bbb", "ccc", "ddd", "eee", "fff", "ggg"};

for (String s : nodeNames) {

graph.nodes.add(new Node(s));

}

graph.arcs = new int[nodeNames.length][nodeNames.length];

Random ra = new Random();

for (int i = 0; i < graph.nodes.size(); i ++){

for (int j = 0; j < graph.nodes.size(); j ++){

if (i != j){

graph.arcs[i][j] = ra.nextInt(100) + 1;

}

}

}

然后是最小生成树的Prim算法实现,解释一下,首先创建一个二维数组表示边,把空间都分配好,只等着往里面填数就行。然后是一个TreeMap对象,来保存顶点,之所以用TreeMap,是为了保证新图的顶点顺序和原图是一致的。剩下的基本就是跟前面算法描述的差不多,大家对着看就行,没什么太难的地方。

public Graph getMinTree(){

int newArcs[][] = new int[this.nodes.size()][this.nodes.size()];

Map newNodes = new TreeMap();

newNodes.put(0, this.nodes.get(0));

while(newNodes.size() != this.nodes.size()){

int minWeight = 99999;

int minI = -1;

int minJ = -1;

for(int i : newNodes.keySet()){

for (int j = 0; j < this.nodes.size(); j ++){

if (i != j && !newNodes.containsKey(j)){

if (this.arcs[i][j] < minWeight){

minWeight = this.arcs[i][j];

minI = i;

minJ = j;

}

}

}

}

newNodes.put(minJ, this.nodes.get(minJ));

newArcs[minI][minJ] = minWeight;

newArcs[minJ][minI] = minWeight;

}

Graph res = new Graph();

res.arcs = newArcs;

res.nodes.addAll(newNodes.values());

return res;

}

下面有一次测试的输出,2个图,分别是原图的所有权值信息,另一个是最小生成树的权值信息

478116e4466c20cbaf0a2aea7395e204.png

997d150ad8a098754b09f7fe9c11fb00.png

然后还可以用连通图的dfs算法检查一下。

Kruskal算法

先将所有边按照权值,从小到大排序

依次访问各边,如果生成回路,则舍弃,否则加入生成树,同时将该边的另一顶点加入生成树

直到所有顶点被加入

java实现,省略。

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

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

相关文章

Android7.0,剪裁后提示“无法保存经过裁剪的图片”

今天在适配一下 7.0的拍照和选择照片&#xff0c;裁剪&#xff0c;发现拍照可以&#xff0c;选择图片也可以&#xff0c; 但是就是裁剪的时候不行&#xff0c;会弹出提示&#xff1a;无法保存经过裁剪的图片 后来才发现&#xff0c;在设置裁剪要保存的 intent.putExtra(MediaSt…

PHP垃圾回收机制理解

使用的是“引用计数”方式进行回收。简单地理解的话&#xff0c;就是每个分配的内存区域都有一个计数器&#xff0c;记录有多少个变量指针指向这片内存。当指向该片内存的指针数量为0&#xff0c;那么该片内存区域就可以被回收。 引用计数计数简单&#xff0c;强大&#xff0c;…

枚举的用法

概念&#xff1a; 为了间接的表示一些固定的值&#xff0c;Java就给提供了枚举&#xff0c;是指将变量的值一一列出来,变量的值只限于列举出来的值的范围内、 特点&#xff1a; 所有枚举类都是Enum的子类我们可以通过”枚举类名.枚举项名称”去访问指定的枚举项每一个枚举项其实…

在php中创建三个表格,创建新工作表PHPExcel

我正在尝试创建另一个工作表,一切正常.但我现在需要的是根据变量创建1.例如 &#xff1a;我有两个选项用于验证,一个用于结果.一切都由一个名为$resultado的布尔变量来约束.我在CakePHP中有我的组件function ExcelCargaMasivaComponent() {$this->xls new PHPExcel();$this…

java.lang.String类

复制下来的java.lang.String源码。在此基础上添加自己的注释&#xff0c;偷懒了&#xff0c;用来加深印象吧。英语不好&#xff0c;没有翻译&#xff0c;不理解的方法直接百度的。然后按照自己的理解描述。/** (#)String.java 1.205 09/02/26** Copyright 2006 Sun Microsys…

面向对象-多态

概念 多态是指同一行为&#xff0c;具有多个不同表现形式 多态是除封装、继承之后面向对象的第三大特征。 多态是出现在继承或者实现关系中的 使用多态有什么前提 要有继承或实现关系要有方法的重写要有父类引用指向子类对象 子类对象是可以赋值给父类类型的变量。例如Animal是…

php 区位码字符,php汉字如何转区位码

php汉字转区位码的方法&#xff1a;首先创建一个PHP示例文件&#xff1b;然后通过“sprintf("%02d%02d",ord($t1[0])-160,ord($t1[1])-160);”方法实现汉字转区位码即可。推荐&#xff1a;《PHP视频教程》PHP中实现汉字转区位码应用源码实例解析PHP里如何实现汉字转区…

ssh(struts,spring,hibernate)开发的初步集成01--依赖

一.概念 SSH 通常指的是 Struts2 做前端控制器&#xff0c;spring 管理各层的组件&#xff0c;hibernate 负责持久化层。 SSM 则指的是 SpringMVC 做前端控制器&#xff0c;Spring 管理各层的组件&#xff0c;MyBatis 负责持久化层。 二.构建流程 创建maven工程...在pom.xml文件…

频谱扩展 matlab,简单的直接扩展频谱通信系统仿真分析

随着通信技术的迅猛发展&#xff0c;扩展频谱通信技术的优点已经越来越明显并被接受&#xff0c;并在各个领域得到了广泛的应用。同时随着计算机技术和仿真技术的日益发展和应用&#xff0c;如何应用一些方便、友好的软件对通信系统进行直观的模型仿真&#xff0c;并进行仿真结…

内部类怎么用

内部类&#xff1a; 在一个类中定义一个类。 举例&#xff1a;在一个类A的内部定义一个类B&#xff0c;类B就被称为内部类 // 格式&#xff1a; class 外部类名{ 修饰符 class 内部类名{ } } class A{public class B {}}内部类的访问特点&#xff1a; 内部类可以直接访问外部类…

一个css3特效

转载于:https://www.cnblogs.com/xiongwei2017/p/6877393.html

matlab保存格式可以用cad打开文件,怎么将TXT文件导入CAD中生成图形

我们可以先把TXT文件转换成WORD或是EXCEL表格里。然后再把转换后的WORD或是EXCEL表格导入到CAD图纸中。这里以迅捷CAD编辑器为例&#xff0c;演示如下&#xff1a;步骤一&#xff1a;还是需要在电脑桌面上安装迅捷CAD编辑器。并进入到软件的操作界面。步骤二&#xff1a;双击打…

[Hnoi2006]马步距离

1285: [Hnoi2006]马步距离 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 36 Solved: 16[Submit][Status][Web Board]Description 在国际象棋和中国象棋中&#xff0c;马的移动规则相同&#xff0c;都是走“日”字&#xff0c;我们将这种移动方式称为马步移动。如右图所示&…

包装类(自动拆箱与自动装箱)

概念&#xff1a; 基本数据类型有8种.基本数据类型效率高,但是功能及其有限,只能做加减乘除运算.为了对基本数据类型进行更多的操作,Java为每种基本数据类型提供了对应的类(包装类)&#xff0c; 作用&#xff1a; 用于基本数据类型与字符串之间的转换 将基本数据类型封装成对象…

php scrscriptipt,XSS挑战之旅闯关笔记

环境自己搭建~~好嚣张&#xff1a;1.http://127.0.0.1:8024/xss/level1.php?nametest 这是URL 看到后面name有参数传递&#xff0c;不多想直接尝试xss。没有任何过滤。payload &#xff1a;http://127.0.0.1:8024/xss/level1.php?name2.http://127.0.0.1:8024/xss/level2.ph…

CentOS7 防火墙规则 (firewalld)

1、firewalld的基本使用启动&#xff1a; systemctl start firewalld查看状态&#xff1a; systemctl status firewalld 停止&#xff1a; systemctl disable firewalld禁用&#xff1a; systemctl stop firewalld2.systemctl是CentOS7的服务管理工具中主要的工具&#xff0c;它…

matlab图像信息熵交叉熵,【机器学习】信息量,信息熵,交叉熵,KL散度和互信息(信息增益)...

首先先强烈推荐一篇外文博客Visual Information Theory这个博客的博主colah是个著名的计算机知识科普达人&#xff0c;以前很是著名的那篇LSTM讲解的文章也是他写的。这篇文章详细讲解了信息论中许多基本概念的前因后果&#xff0c;并且很是的直观用了大量的图片&#xff0c;和…

第2章第1讲数据类型及常量变量

#include"stdio.h"main() {printf("I love music!\n");printf("the music is \"D:\\music\\love.mp3\".\n");} #include "stdio.h" #define PI 3.14 //符号常量 main() {float r,area; …

java嵌套对象,java – 从嵌套流中收集一组对象

我有一个场景,我有两个for循环,一个嵌套在另一个.在内部循环中,对于每次迭代,我都有创建特定类型的新实例所需的信息.我想将代码从for循环更改为使用流,因此我可以将所有对象收集到ImmutableSet中.但是,我无法制作一个编译和工作的版本.下面的示例程序说明了我最接近的尝试.它编…

v$session v$session_wait

(1)v$session v$session视图记录了当前连接到数据库的session信息 ColumnDescriptionSADDRsession addressSIDSession identifierSERIAL#session序列号&#xff0c;当某个session结束&#xff0c;另一个新开始的session使用了前者的sid&#xff0c;则此数值自加1AUDSIDauditing…