


全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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年森林环境考试题目及答案
- 燃煤发电环保设施建设方案
- 高级绿化考试试题及答案
- 社会保险基金应收账款质押担保及区块链技术应用合同
- 金融行业员工岗位调整及劳动合同完善协议
- 环保项目环评咨询与实施合同
- 离婚协议书贷款还款及财产分割执行细则合同
- 企业环境管理体系建设与节能减排方案
- 物业让与担保及能源管理系统建设合同范本
- 锚杆施工合同范本
- 2024土建工程承包合同范
- 广东高职高考数学题分类
- 掘进支护安全培训课件
- 新概念二单词表
- 《雅思阅读技巧》课件
- 《建筑工程测量》教学教案
- 《影视美学教学》课件
- 小学道德与法治-主动拒绝烟酒与毒品(第一课时)教学设计学情分析教材分析课后反思
- 《工会固定资产管理办法》中华全国总工会办公厅印发
- 单人心肺复苏技术操作考核评分标准
评论
0/150
提交评论