bellman ford java_Java C 实现Bellman-ford算法

0818b9ca8b590ca3270a3433284dd417.png

package com.cn.tree;

public class MyException extends Exception {

private static final long serialVersionUID = 1L;

public MyException(String str) {

super(str);

}

public MyException() {}

}

package com.cn.graph;

import com.cn.tree.MyException;

/**

* 很明显时间复杂度为O(VE),因为每一次需要对边进行松弛,所以我们采用保存边的方式来存储图的的信息。

* p保存的是前驱节点,d保存的是源点到每一个点的最短距离。我们最后又做了一次判断,如果还有可以松弛

* 的边,那么可以保证的是图中有负权的环存在,这样的话就没有最短路径只说了,可以无限小。

*

* @author daijope

*

*/

public class BellmanFord {

private static final int m = 10000;

public static void main(String[] args) throws MyException {

Adge a1 = new Adge(0, 1, -1);

Adge a2 = new Adge(0, 2, 4);

Adge a3 = new Adge(1, 2, 3);

Adge a4 = new Adge(3, 1, 1);

Adge a5 = new Adge(1, 3, 2);

Adge a6 = new Adge(3, 2, 5);

Adge a7 = new Adge(1, 4, 2);

Adge a8 = new Adge(4, 3, -3);

Adge[] as = new Adge[]{a1, a2, a3, a4, a5, a6, a7, a8};

int[] d = new int[5];

int[] p = new int[5];

d[0] = 0;

p[0] = 0;

for (int i = 1; i < d.length; i++) {

d[i] = m;

p[i] = -1;

}

bellman_Ford(as, d, p);

for (int i = 0; i < d.length; i++) {

System.out.println(d[i]);

}

}

private static void bellman_Ford(Adge[] as, int[] d, int[] p) throws MyException {

for(int i = 1; i < d.length; i++) {

for (int j = 0; j < as.length; j++) {

if (d[as[j].getV()] > d[as[j].getU()] + as[j].getW()) {

d[as[j].getV()] = d[as[j].getU()] + as[j].getW();

p[as[j].getV()] = as[j].getU();

}

}

}

for (int j = 0; j < as.length; j++) {

if (d[as[j].getV()] > d[as[j].getU()] + as[j].getW()) {

throw new MyException("有负环");

}

}

}

}

class Adge {

private int u;

private int v;

private int w;

public Adge(int u, int v, int w) {

this.u = u;

this.v = v;

this.w = w;

}

public int getU() {

return u;

}

public void setU(int u) {

this.u = u;

}

public int getV() {

return v;

}

public void setV(int v) {

this.v = v;

}

public int getW() {

return w;

}

public void setW(int w) {

this.w = w;

}

}

c语言实现:

#include

#define MAXVALUE 10000

typedef struct node

{

int u;

int v;

int w;

};

bool BELLMAN_FORD(node G[])

{

int dis[5],pre[5],p[5];

int i,j,k;

for(i=0;i<=4;i++)

{

dis[i]=MAXVALUE;

pre[i]=-1;

p[i]=1;

}

dis[G[0].u]=0;

for(j=1;j<=4;j++)

{

for(i=0;i<=7;i++)

{

if(dis[G[i].v]>dis[G[i].u]+G[i].w)

{

dis[G[i].v]=dis[G[i].u]+G[i].w;

pre[G[i].v]=G[i].u;

}

}

}

for(i=1;i<=7;i++)

{

if(dis[G[i].v]>dis[G[i].u]+G[i].w)

return false;

}

for(i=0;i<=7;i++)

{

if(p[G[i].v]==1)

{

printf("%d %d\n",G[i].v,dis[G[i].v]);

k=G[i].v;

p[G[i].v]=0;

while(pre[k]!=-1)

{

printf("%d \n",pre[k]);

k=pre[k];

}

}

}

return true;

}

int main()

{

node G[8];

G[0].u=0;

G[0].v=1;

G[0].w=-1;

G[1].u=0;

G[1].v=2;

G[1].w=3;

G[2].u=1;

G[2].v=2;

G[2].w=3;

G[3].u=1;

G[3].v=3;

G[3].w=2;

G[4].u=1;

G[4].v=4;

G[4].w=2;

G[5].u=3;

G[5].v=1;

G[5].w=1;

G[6].u=3;

G[6].v=2;

G[6].w=5;

G[7].u=4;

G[7].v=3;

G[7].w=-3;

BELLMAN_FORD(G);

getchar();

}

//O(VE)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/526685.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

c#模拟看板控件_在Winform界面使用自定义用户控件及TabelPanel和StackPanel布局控件...

在很多时候&#xff0c;我们做一些非常规化的界面的时候&#xff0c;往往需要创建一些用户控件&#xff0c;在其中绘制好一些基础的界面块&#xff0c;作为后续重复使用的一个单元&#xff0c;用户控件同时也可以封装处理一些简单的逻辑。在开发Winform各种类型项目&#xff0c…

java jdbc 详解_JDBC概述及详解各个对象

JDBC(Java DataBase Connectivity)详解一.概念&#xff1a;JDBC是一种可执行SQL语句的JavaAPI&#xff0c;Java数据库链接&#xff0c;Java语言操做数据库mysql二.本质&#xff1a;JDBC是一种可用于执行SQL语句的Java API&#xff0c;由一些Java语言编写的类和页面组成。各个数…

java非递归_Java非递归文件系统走路

我需要创建一个使用非递归遍历文件系统的应用程序,并打印出一定深度的文件.是)我有的&#xff1a;public void putFileToQueue() throws IOException, InterruptedException {File root new File(rootPath).getAbsoluteFile();checkFile(root, depth);Queue queue new ArrayD…

private访问权限java_Java中的访问权限控制

Java提供了public, private, protected 三个访问权限修饰词&#xff0c;提供了以下四种访问权限控制机制&#xff1a;1、包访问权限&#xff1b;2、Public访问权限&#xff1b;3、Private访问权限&#xff1b;4、Protected访问权限&#xff1b;1、包访问权限包访问权限是Java为…

java查看蓝牙mac地址_Java如何获取主机的MAC地址?

以前&#xff0c;为了获取MAC地址&#xff0c;我们需要使用本机代码作为解决方案。在JDK 1.6中&#xff0c;java.net.NetworkInterface类中添加了一个新方法&#xff0c;该方法为getHardwareAddress()。package org.nhooo.example.network;import java.net.InetAddress;import …

java空心字木塔_我国七个千年古塔:第四个空心没有塔顶,最后一个是木塔无钉无铆...

1、崇圣寺三塔&#xff0c;云南大理&#xff0c;公元824—839年崇圣寺三塔是一个三塔三阁组成的建筑群&#xff0c;最大的主塔又名千寻塔。是中国现存层数最多的古佛塔&#xff0c;拥有16层。崇圣寺三塔历经30多次地震不倒&#xff0c;极其顽强。2、大雁塔&#xff0c;陕西西安…

java8 ie_Java8语法糖之Lambda表达式_Hudie.的博客-CSDN博客

原文作者&#xff1a;编程一只蝶原文标题&#xff1a;Java8语法糖之Lambda表达式发布时间&#xff1a;2021-02-16 13:08:40一、Lambda表达式简介Lambda表达式&#xff0c;是Java8的一个新特性&#xff0c;也是Java8中最值得学习的新特性之一。(另一个新特性是流式编程。)Lambda…

python中的event_Python event

最新项目游戏感用于SteelSeries GameSense 3.8.x的Python库安装这个包有两个不同的版本。一个支持普通的同步函数调用&#xff0c;另一个支持python的异步功能。要安装同步版本&#xff0c;请运 ...2021-03-02已阅读: n次此模块验证事件模块中的电话号码&#xff0c;就像base_p…

hadoop 运行java类_hadoop运行java类

使用hadoop运行自己写的java类报错&#xff1a;/home/hadoop/bin/hadoop MaxTemperature /home/hadoop/input/sample.txt outputException in thread "main" java.lang.NoClassDefFoundError: MaxTemperatureCaused by: java.lang.ClassNotFoundException: MaxTemper…

centos的mysql怎么删用户_linux/centos给Mysql创建用户、授权、查看、删除、修改密码、撤...

linux/centos给Mysql创建用户、授权、查看、删除、修改密码、撤linux/centos给Mysql创建用户、授权、查看、删除、修改密码、撤销权限linux/centos给Mysql创建用户、授权、查看、删除、修改密码、撤销权限root权限高&#xff0c;安全性考虑&#xff0c;一般只允许本地(本机)访问…

采取 过滤 php_这3种php高级过滤了解一下,很实用!

在php中有很多的过滤&#xff0c;可以对输入的字符串进行过滤&#xff0c;同时也可以对邮件地址进行过滤&#xff0c;接下来我要讲的是php中的3种高级过滤&#xff0c;在开发中很实用。第一种&#xff1a;过滤数值范围在php经常要接收各种数据&#xff0c;其中数值是非常普遍的…

java打乱一组正序数字,Leetcode︱4.Median of Two Sorted Arrays寻找两个正序数组的中位数.java...

题目给定两个大小分别为 m 和 n 的正序(从小到大)数组 nums1 和 nums2。请你找出并返回这两个正序数组的 中位数 。示例 &#xff1a;输入&#xff1a;nums1 [1,3], nums2 [2]输出&#xff1a;2.00000解释&#xff1a;合并数组 [1,2,3] &#xff0c;中位数 2说明:nums1.leng…

php中的oop思想,避免OOP的形式,POP的思想_PHP

避免OOP的形式,POP的思想_PHP避免OOP的形式,POP的思想好久没发技术性文章了,今天在21PHP里看到有位兄弟发了这贴子,转了过来.对加强OOP的学习有些用----------------------------------------------------------避免OOP的形式,POP的思想随着PHP对OOP(面向对象编程)支持的增强以…

吃PHP小孩智力好,这7种鱼千万不能给孩子吃,会影响孩子的智力!

所以&#xff0c;给宝宝添加鱼类时一定要注意&#xff0c;有7种鱼含有大量金属元素&#xff0c;是千万不能给宝宝吃的&#xff01;1罗非鱼罗非鱼深青色的外表有几分像鲫鱼。由于罗非鱼的成长周期较长&#xff0c;它们体内汞的含量也就相比其他鱼偏高&#xff0c;小朋友吃罗非鱼…

java监控rabbitMq服务状态,spring cloud 的监控turbine-rabbitmq的示例

前提是你已经有了注册中心,然后搭建一个基础spring cloud 服务,并配置注册服务等等前提环境搭建接下来描述的服务提供者和服务调用者的配置都是一样的,来自《spring cloud 与 docker微服务架构实战》的读后的个人总结.pom文件中需要引入spring-cloud-starter-hystrix/spring-cl…

支付宝php40247,支付宝APP支付 显示 系统繁忙 请稍后再试 ALI40247

PHP服务端生成地址传给IOS端调用 一直显示系统繁忙 请稍后再试 ALI40247 密钥也正常 也按照官方说明来走。官方的PHP端SDK是错误的 根本不加密biz_content 字段随后百度找不到相关的资料 只有人说换成 1.0版本 也就是 移动支付移动支付相关文档 https://doc.open.alipay.com…

java jlabel构造方法,浅谈标签和JLabel类构造方法 原创

搜索热词标签有 JLabel 类定义&#xff0c;它的父类为 JComponet 类。标签可以显示一行只读文本、一个图像或带图像的文本。它并不能产生任何类型的事件&#xff0c;只能简单地展示图片和文本&#xff0c;但是可以使用标签的特性指定标签上文本的对齐方式。JLabel类提供了多种构…

php改变iframe的src,js动态改变iframe的src属性

今天在Chrome下显示如下的iframe&#xff0c;src设置为空&#xff0c;但打开页面时iframe一直处于刷新状态&#xff0c;看了下面的博文&#xff0c;觉得是不是默认不显示时src应该写成about:blank&#xff0c;明天回去测试下&#xff0c;回来更新结果写一个&#xff0c;src地址…

java弹球轨迹运动解说,动态弹球的实现 加入了多线程技术-javaSE游戏准备工作

动态弹球的实现 加入了多线程技术--javaSE游戏准备工作任务描述:实现了动态弹球的功能&#xff0c;对于有弹球功能的SE游戏奠定了基础。package 运用线程技术的小球;import java.awt.*;import java.awt.event.*;import java.awt.geom.*;//不清楚这个有什么用import java.util.*…

Java语言矩形与立方体的继承,沈阳师范大学大一下册C++语言PTA题目集以及答案(编程题篇)...

沈阳师范大学大一下册C语言PTA题目集以及答案(编程题篇)7-1 测试c (20分)倒序输出从控制台输入的n个整数输入格式:第一行输入一个数n&#xff0c;代表行数依次输入n个整数输出格式:将n个整数倒序输出输入样例:31 2 3输出样例:321#includeint main(){int n,i;std::cin>>i;…