弗洛伊德算法怎么理解_弗洛伊德算法思想

弗洛伊德算法怎么理解_弗洛伊德算法思想这个方法中,其中每一个顶点到另一个顶点最多就是两步。所以就是找到两个顶点的最近距离packagea;importjava.lang.reflect.Array;importjava.util.Arrays;publicclassFloydDemo{publicstaticvoidmain(String[]args){char[]di…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

这个方法中,其中每一个顶点到另一个顶点最多就是两步。
所以就是找到两个顶点的最近距离

package a;

import java.lang.reflect.Array;
import java.util.Arrays;

public class FloydDemo { 
   
    public static void main(String[] args) { 
   
        char[] diots = { 
   'A', 'B', 'C', 'D', 'E', 'F', 'G'};
        int[][] edges = new int[diots.length][diots.length];
        final int N = 65535;

        edges[0]=new int[]{ 
   0,5,7,N,N,N,2};//注意这个自身到自身的距离是0 ,并不是N 和地杰斯特拉的区别
        edges[1]=new int[]{ 
   5,0,N,9,N,N,3};
        edges[2]=new int[]{ 
   7,N,0,N,8,N,N};
        edges[3]=new int[]{ 
   N,9,N,0,N,4,N};
        edges[4]=new int[]{ 
   N,N,8,N,0,5,4};
        edges[5]=new int[]{ 
   N,N,N,4,5,0,6};
        edges[6]=new int[]{ 
   2,3,N,N,4,6,0};

        FGraph fGraph = new FGraph(diots, edges, diots.length);
        fGraph.floyd();
        fGraph.show();
    }
}

class FGraph{ 
   
    char [] data;
    int [] [] dis;
    int [][] pre;

    public FGraph(char[] data, int[][] dis, int len) { 
   
        this.data = data;
        this.dis = dis;
        pre = new int[len][len];
        for (int i = 0; i < data.length; i++) { 
   

            Arrays.fill(pre[i],i);//每个顶点的前驱节点默认值是自身的下标。和地杰斯特拉不一样,地杰斯特拉默认不初始化。
        }
    }


    public void show(){ 
   
        for (int i = 0; i < data.length; i++) { 
   
            for (int j = 0; j < data.length; j++) { 
   
                System.out.print(data[pre[i][j]]+"\t");
            }
            System.out.println();
            for (int j = 0; j < data.length; j++) { 
   
                System.out.print("("+data[i]+"-->"+data[j]+":"+dis[i][j]+"|\t");
            }
            System.out.println();
        }

    }

    public void floyd(){ 
   
        int len =0;//变量保存距离
        for (int i = 0; i < data.length; i++) { 
   //中间
            for (int j = 0; j < data.length; j++) { 
   //起点
                for (int k = 0; k < data.length; k++) { 
   //终点
                    len = dis[j][i]+dis[i][k];
                    if (len < dis[j][k]) { 
   
                        dis[j][k] = len;
                        pre[j][k] = pre[i][k];//这个是更新前一个顶点。在初始化的时候pre 的每一行都是 自身。所以,这个第一次是自身。然后变成了中间的这个点。
                    }
                }
            }
        }

    }

}



Jetbrains全家桶1年46,售后保障稳定

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/203585.html原文链接:https://javaforall.net

(0)
上一篇 2025年8月12日 下午8:43
下一篇 2025年8月12日 下午9:22


相关推荐

  • java标识符命名_java标识符命名规则「建议收藏」

    java标识符命名_java标识符命名规则「建议收藏」1.标识符概念:对于java中的类、接口、变量、常量、方法、属性等等命名的字段被称作标识符。通俗的说就是起名字的地方就是标示符。2标识符命名规则:(1).标识符一般有字母、数字、下划线_、美元符$、人民币符号¥组成。(2).注意数字不能放开头(3).不能把java关键字(例如publicint)作为标识符(4).不能把java保留字(goto,const)作为标识符(5).标识符没有长度限制,并…

    2022年7月26日
    12
  • webapp开发框架推荐以及优缺点分析【webAPP干货】[通俗易懂]

    webapp开发框架推荐以及优缺点分析【webAPP干货】[通俗易懂]推荐下面6款常用的webapp开发框架。有兴趣可以阅读《HTML5移动webAPP和HybridAPP开发的优缺点分析》和2014年webAPPUI设计和前端JS特效案例集萃第一款:Sencha TouchSenchaTouch是世界上第一个支持HTML5和CSS3标准的移动应用框架,你可以使用HTML5来编写音频和视频组件,还可以使用Lo

    2022年6月15日
    39
  • Java中打印对象内存地址

    Java中打印对象内存地址Object 的 hashCode 默认是返回内存地址的 但是 hashCode 可以重写 所以 hashCode 不能代表内存地址的不同 System identityHash Object 方法可以返回对象的内存地址 不管该对象的类是否重写了 hashCode 方法 下面来验证 publicclassT publicstatic Strin

    2026年3月19日
    2
  • 在本地磁盘型云主机做软RAID的实践[通俗易懂]

    在本地磁盘型云主机做软RAID的实践[通俗易懂]在本地磁盘型云主机做软RAID的实践

    2022年4月21日
    53
  • java:闰年判断程序[通俗易懂]

    java:闰年判断程序[通俗易懂]公历闰年的简单计算方法(符合以下条件之一的年份即为闰年)1、能被4整除而不能被100整除。2、能被400整除。方案:使用数学运算符取余运算(%),关系运算符等于(==)和不等于(!=),辑运算符逻辑与(&&)和逻辑或(||),来判断某年是否为闰年,判断的结果为boolean类型的值,如果为闰年boolean类型的值为true,否则为falsebooleanflag=(year%4==0&&year%100!=0)||year%400==0

    2022年7月17日
    15
  • matlab 计算变异系数,变异系数法求权重matlab 代码[通俗易懂]

    matlab 计算变异系数,变异系数法求权重matlab 代码[通俗易懂]利用matlab编程,很容易根据变异系数法,求得多指标综合评价模型的权重。代码如果有不懂的地方,可以联系我。变异系数法求权重matlab代码clear;clc;[data1,header1]=xlsread(‘statistic1.xlsx’,’ECO’);%必须将statistic.xlsx至于默认文件下,或者给出完整路径[data2,header2]=xlsread(‘stati…

    2022年6月11日
    62

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号