


全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Kruskal算法求最小生成树(JAVA)代码:package homework;import java.util.Scanner; import java.util.Arrays; import java.util.ArrayList; class Edge public int start;/始边 public int end;/终边 public double cost;/权重 public class MinSpanningTree_Kruskal private static int MAX = 100; private ArrayList edge = new ArrayList();/整个图的边 private ArrayList target = new ArrayList();/目标边,最小生成树 private int parent = new intMAX;/标志所在的集合 private static double INFINITY = 99999999.99;/定义无穷大 private double mincost = 0.0;/最小成本 private int n;/结点个数 public MinSpanningTree_Kruskal() public static void main(String args) MinSpanningTree_Kruskal sp = new MinSpanningTree_Kruskal(); sp.init(); sp.kruskal(); sp.print(); /初始化 public void init() Scanner scan = new Scanner(System.in); int p,q; double w; System.out.println(请输入结点个数:); n = scan.nextInt(); System.out.println(请输入各条边及权值(每次输入一组数据按回车确认, + 最后输入-1 -1 -1 结束输入过程)); while(true) p = scan.nextInt(); q = scan.nextInt(); w = scan.nextDouble(); if(p 0 | q 0 | w 0) break; Edge e = new Edge(); e.start = p; e.end = q; e.cost = w; edge.add(e); mincost = 0.0; for(int i = 1; i = n; +i) parenti = i; /集合合并 public void union(int j, int k) for(int i = 1; i = n; +i) if(parenti = j) parenti = k; /prim算法主体 public void kruskal() /找剩下的n-2条边 int i = 0; while(i 0) /每次取一最小边,并删除 double min = INFINITY; int tag = 0; Edge tmp = null; for(int j = 0; j edge.size(); +j) Edge tt = edge.get(j); if(tt.cost min) min = tt.cost; tmp = tt; int jj = parenttmp.start; int kk = parenttmp.end; /去掉环 if(jj != kk) +i; target.add(tmp); mincost += tmp.cost; union(jj,kk); edge.remove(tmp); if(i != n-1) System.out.println(没有最小生成树); System.exit(0); /打印结果 public void print() double sum=0; System.out.println(最小生成树:); for(int i = 0; i target.size(); +i) Edge e = target.get(i); System.out.println(第 + (i+1) + 条边: + e
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 目标客户群体画像构建-洞察及研究
- 大数据监控框架设计-洞察及研究
- 2025年乡村医生考试题库:农村妇幼保健知识健康促进政策分析试题
- 2025年辅导员职位选拔考试题库-学生职业生涯规划职业生涯规划教育与心理健康辅导试题
- 2025-2030工业元宇宙数字工厂建模精度要求与仿真软件功能迭代路径
- 2025-2030工业元宇宙平台开发工具生态与制造业虚拟培训需求预测
- 2025-2030工业互联网设备指纹安全认证体系研究
- 2025-2030工业互联网时间敏感网络对时钟精度的新需求报告
- 局部免疫反应与自身免疫病-洞察及研究
- 2025-2030工业互联网平台核心技术突破与垂直行业渗透率调查报告
- 中国近代史课件
- 2022年军队文职考试《数学1》真题-1
- 小学道德与法治-主动拒绝烟酒与毒品(第一课时)教学设计学情分析教材分析课后反思
- 五上3-2《用水计量时间》课件
- 常用截面惯性矩与截面系数的计算
- 供应商黑名单管理办法
- 单人心肺复苏技术操作考核评分标准
- 2023年java程序设计试题库
- 初一英语英语语法总结课件
- 酸碱平衡紊乱模型的复制和解救课件
- 管理养老机构 养老机构的运营
评论
0/150
提交评论