当前位置: 首页 > news >正文

医院网站推广渠道旅游网站设计参考文献

医院网站推广渠道,旅游网站设计参考文献,做二手车网站怎么做的,做基本的网站实现描述 为了造出一棵最小生成树,我们从最小边权的边开始,按边权从小到大依次加入,如果某次加边产生了环,就扔掉这条边,直到加入了 n-1 条边,即形成了一棵树。 实现代码 首选我们对所有的边&#xff0c…

实现描述

为了造出一棵最小生成树,我们从最小边权的边开始,按边权从小到大依次加入,如果某次加边产生了环,就扔掉这条边,直到加入了 n-1 条边,即形成了一棵树。

实现代码

  1. 首选我们对所有的边,按照权重排序;
  2. 之后,从小到大选择边,如果当前的边已经连通过了,则放弃此边,查看下一条边;若没有连通过,通过并查集进行连通;
  3. 直至所有点都访问过,此时,完成。

在这里插入图片描述

如上图,节点0~5,边关系如上;
先对边权重进行从小到大排序,得到:

[{"u":4,"v":5,"weight":1
},{"u":0,"v":5,"weight":3
},{"u":1,"v":2,"weight":4
},{"u":0,"v":1,"weight":5
},{"u":2,"v":3,"weight":5
},{"u":3,"v":4,"weight":5
},{"u":3,"v":5,"weight":6
},{"u":0,"v":3,"weight":7
},{"u":0,"v":2,"weight":8
},{"u":2,"v":5,"weight":9
}]

然后依次选择排序后的边:
在这里插入图片描述
下面代码对应上图数据及其过程:

import com.alibaba.fastjson.JSONObject;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.jetbrains.annotations.NotNull;import java.util.*;public class kruskal {/*** 边定义*/@Data@AllArgsConstructor@NoArgsConstructorstatic class Edge implements Comparable<Edge> {int u, v;int weight;@Overridepublic int compareTo(@NotNull Edge o) {return weight - o.weight;}}static List<Edge> getKruskalEdges(int nodeNum, int[][] grid) {List<Edge> result = new LinkedList<>();List<Edge> edges = new LinkedList<>();for (int i = 0; i < grid.length; i++) {int u = grid[i][0];int v = grid[i][1];int weight = grid[i][2];edges.add(new Edge(u, v, weight));}Collections.sort(edges);UnionFindTemplate uf = new UnionFindTemplate(nodeNum);Set<Integer> visited = new HashSet<>();for (Edge edge : edges) {if (uf.connected(edge.u, edge.v)) {continue;}uf.union(edge.u, edge.v);visited.add(edge.u);visited.add(edge.v);result.add(edge);if (visited.size() == nodeNum) {break;}}return result;}public static void main(String[] args) {int nodeNum = 6;int[][] grid = {{0, 1, 5},{0, 5, 3},{0, 3, 7},{0, 2, 8},{1, 2, 4},{2, 5, 9},{3, 5, 6},{2, 3, 5},{3, 4, 5},{4, 5, 1}};System.out.println(JSONObject.toJSONString(getKruskalEdges(nodeNum, grid)));}
}

其中,并查集模版的实现如下:

public class UnionFindTemplate {int[] parent;int[] size;int n;public int setCount;//连通分量个数public UnionFindTemplate(int n) {this.n = n;this.parent = new int[n];this.size = new int[n];setCount = n;Arrays.fill(this.size, 1);for (int i = 0; i < n; ++i) {parent[i] = i;}}public int findParent(int x) {if (parent[x] == x) {return x;} else {parent[x] = findParent(parent[x]);return parent[x];}}public void union(int x, int y) {x = findParent(x);y = findParent(y);if (x == y) {return;}if (size[x] < size[y]) {int temp = x;x = y;y = temp;}//y合并到xparent[y] = x;size[x] += size[y];setCount--;}public boolean connected(int x, int y) {x = findParent(x);y = findParent(y);return x == y;}}
http://www.yayakq.cn/news/318092/

相关文章:

  • 河南省建设厅网站打不开抖音小程序开通
  • 重庆免费网站制作企业管理系统oa
  • 鱼馆网站的前期策划c2c平台是指什么
  • 公司网站搜索优化学网站建设难吗
  • 构建电子商务网站的步骤windows搭建wordpress博客
  • 沈阳的网站建设开源社区的发展前景
  • 深圳网站营销推广公司电话网站建设要不要工商注册
  • 做房地产资质是什么网站查短视频排名seo
  • 沈阳做网站优化哪家好公司网站应该怎么做
  • 湖北网站建设哪家有河北优化网站获客qq
  • 最先进的无锡网站建设网站承建
  • 做一个网站做少钱免费一键生成详情页
  • 网站建设 中企动力上海东莞网站建设收费明细
  • 河北专业网站建设公司推荐公司注册费用与流程
  • 利津网站建设卖摄影作品的网站
  • 如何购买网站流量做文案策划需要用到的网站
  • 网站建设 完成做网站有哪些要求
  • 西安市城乡与住房建设厅网站手机推广赚钱平台
  • 做网站番禺网店怎么开要多少钱
  • 网站怎样制作图文排版百度关键词搜索广告的优缺点
  • 高端企业网站设计成都设计公司排行建筑设计公司
  • wordpress 商品插件乐山网站seo
  • 网站建设项目策划书范文如何做的mmd下载网站
  • 新闻资讯网站php源码网银汇款企业做网站用途写什么
  • 广州 网站制作网络推广目标怎么写
  • ae模板免费网站wordpress网店模板制作
  • 做网站如何与网络公司沟通搭建展厅设计展览设计
  • ps如何做网站首页创可贴在线设计平台
  • 山东建设兵团网站淘宝客推广平台
  • 什么网站能接工地做链家网站开发