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

武汉一医院网站建设中超最新积分榜

武汉一医院网站建设,中超最新积分榜,电商是做什么的?,网站外链建设方案前言:使用最小生成树的方法解决将所有节点连接起来所需的最小路径问题。 prim算法 Prim算法是一种贪心算法,从任意一个顶点开始构建最小生成树。每次选择当前已加入生成树的顶点中,距离最近的尚未加入生成树的顶点,直到所有顶点…

前言:使用最小生成树的方法解决将所有节点连接起来所需的最小路径问题。

prim算法

Prim算法是一种贪心算法,从任意一个顶点开始构建最小生成树。每次选择当前已加入生成树的顶点中,距离最近的尚未加入生成树的顶点,直到所有顶点都被加入生成树。

适用场景

  • 稠密图:Prim算法在稠密图(边数接近 n2 )中表现较好,因为它的复杂度为O(n^2),其中 n 为节点数量。
  • 单源最短路径:Prim算法可以从任意一个顶点开始构建最小生成树,适合需要从特定顶点开始的情况。
代码实现

prim三部曲:
第一步,选距离生成树最近节点
第二步,最近节点加入生成树
第三步,更新非生成树节点到生成树的距离(即更新minDist数组)

minDist数组 用来记录 每一个节点距离最小生成树的最近距离。由于题目中说了边的权重最大为10000,这里将边的最大值初始化为10001。

代码如下:

import java.util.*;
public class Main{public static void main (String[] args) {Scanner scan=new Scanner(System.in);int v=scan.nextInt();int e=scan.nextInt();int[][] grid=new int[v+1][v+1];//初始化距离为1001for(int i=0;i<=v;i++){Arrays.fill(grid[i],10001);}//根据输入的边的权值建立地图for(int i=0;i<e;i++){int s=scan.nextInt();int t=scan.nextInt();int k=scan.nextInt();grid[s][t]=k;grid[t][s]=k;}//初始化最小距离为10001int[] minDist=new int[v+1];Arrays.fill(minDist,1001);//建立数组判断节点是否在树中boolean[] isInTree=new boolean[v+1];//先选择第一个节点加入树中minDist[1]=0;//外部循环,遍历每一个节点for(int i=1;i<=v;i++){int minVal=Integer.MAX_VALUE;int cur=-1;//找到不在树中且距离最近的节点for(int j=1;j<=v;j++){if(!isInTree[j] && minDist[j]<minVal){minVal=minDist[j];cur=j;}}//将当前节点加入树中isInTree[cur]=true;//更新节点到数的距离,主要更新与新加入的节点相连的节点for(int j=1;j<=v;j++){if(!isInTree[j] && grid[cur][j]<minDist[j]){minDist[j]=grid[cur][j];}}}//prim算法的循环结束,计算路径总和int result=0;for(int i=2;i<=v;i++){result+=minDist[i];}System.out.println(result);}
}

注意:外部循环是为了确保每个节点都被遍历到。第一个内部循环是找到距离最小生成树最近的节点;第二个内部循环是更新minDist。

kruskal算法

Kruskal算法也是一种贪心算法,但它是从全局角度出发,先将所有边按权重从小到大排序,然后依次选择不形成环的边加入生成树,直到生成树包含所有顶点。

适用场景

  • 稀疏图:Kruskal算法在稀疏图(边数远小于 n2)中表现较好,因为它的复杂度为 nlogn,其中n 为边的数量。
  • 全局最优:Kruskal算法从全局角度出发,适合需要考虑所有边的情况。

代码实现

在代码中,我们可以使用并查集将两个节点加入同一个集合并判断两个节点是否在同一个集合。
时间复杂度:nlogn (快排) + logn (并查集) ,所以最后依然是 nlogn ,n为边的数量。

代码如下:

import java.util.*;
//定义边的类
class Edge{int l,r,val;Edge(int l,int r,int val){this.l=l;this.r=r;this.val=val;}
}public class Main{//题目中节点最多10000,所以初始化并查集的节点10001public static int n=10001;public static int[] father=new int[n];public static void init(){for(int i=0;i<n;i++){father[i]=i;}}public static int find(int u){return u==father[u]?u:(father[u]=find(father[u]));}public static void join(int u,int v){u=find(u);v=find(v);if(u==v) return;else father[v]=u;}public static void main (String[] args) {Scanner scan=new Scanner(System.in);int v=scan.nextInt();int e=scan.nextInt();List<Edge> edgeList=new LinkedList<>(); for(int i=0;i<e;i++){int l=scan.nextInt();int r=scan.nextInt();int val=scan.nextInt();edgeList.add(new Edge(l,r,val));}//排序edgeList.sort(Comparator.comparingInt(edge -> edge.val));init();int result=0;for(Edge edge:edgeList){int x=find(edge.l);int y=find(edge.r);if(x!=y){result+=edge.val;join(x,y);}}System.out.println(result);}
}
http://www.ds6.com.cn/news/25682.html

相关文章:

  • 顾村网站建设今天上海重大新闻事件
  • 企业网站管理系统有哪些百度搜索风云榜明星
  • 投简历的平台seo专员是什么意思
  • 网站建设const是什么意思新网站推广方法
  • 养生网站建设免费线上招生引流推广方法
  • 做的比较好的意大利网站宁波网络推广联系方式
  • 旅游网站开发本科论文排名优化关键词公司
  • asp网站做搜索网站平台推广
  • 施工企业主要负责人包括重庆seo霸屏
  • 高端网站建设联系方式百度怎么注册公司网站
  • 网站建设 的系统公式网站制作过程
  • 做网站一般什么价格总推荐榜总点击榜总排行榜
  • facebook做网站推广seo模拟点击
  • 域名服务器购买石家庄全网seo
  • 江苏连云港网站制作公司seo研究所
  • 上饶做网站国际域名注册网站
  • 设计素材网站花瓣seo网站推广实例
  • 小说网站收录了怎么做排名h5下一页
  • 个人网站如何赚钱东莞网站开发公司
  • 群晖wordpress站点地址域名是什么
  • 深圳装修公司网站站内营销推广方式
  • 网站 配色whois查询
  • 汕头cms建站模板百度竞价渠道代理商
  • 互联网科技公司做网站哪家好sem营销推广
  • 做盗版视频网站成本多少百度人工申诉客服电话
  • 襄阳做网站比较有实力的公司什么是网络营销战略
  • 广东网站设计品牌设计小江seo
  • 网站后台 开源seo关键词排名实用软件
  • 武汉网站建设公司027广告投放这个工作难不难做
  • 天津市住房和城乡建设委员会网站网站seo专员