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空心字木塔_我国七个千年古塔:第四个空心没有塔顶,最后一个是木塔无钉无铆...

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…

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;其中数值是非常普遍的…

吃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…

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

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

asp php 用户登录,一个简单的asp.net 单点登录实现

以下是实现的效果图&#xff1a;首先上图的点击火车订票链接&#xff0c;就会打开http://学生信息平台网站/LoginToTrainSite.asa页面。LoginToTrainSite.asa页面的大致代码如下&#xff1a;Response.Buffer TrueResponse.ExpiresAbsolute Now() - 1Response.Expires 0Respo…

ajax怎么发送数据给php,ajax怎么发送数据给php

在网上看了很久&#xff0c;发现数据的利用ajax提交数据到后台其实很简单&#xff0c;但是很多讲解的并不清楚&#xff0c;对于初学者来说&#xff0c;很多真的是看着有点糊涂&#xff0c;拿来直接用&#xff0c;又想去了解怎么回事&#xff0c;其实利用ajax提交数据到后台是非…

oracle10无法安装打开,64位win10添加oracle odbc驱动时提示无法加载oracle怎么办

对于win10 64位系统添加oracle odbc驱动时提示无法加载oracle的问题相信部分用户都应该有所了解了&#xff0c;但是对于如何解决这个问题的实际操作的用户来说可能不多&#xff0c;因此&#xff0c;为了帮助出现这种问题的用户&#xff0c;小编在这里就来教大家64位win10添加or…

linux postgresql默认安装目录,postgresql - 三种安装方式(示例代码)

最近接触了postgresql的安装&#xff0c;和大家分享一下。一、简 介PostgreSQL 是一种非常复杂的对象-关系型数据库管理系统(ORDBMS)&#xff0c;也是目前功能最强大&#xff0c;特性最丰富和最复杂的自由软件数据库系统。有些特性甚至连商业数据库都不具备。这个起源于伯克利(…

linux中央服务器,如何在Linux上搭建一个Git中央仓库

前言&#xff1a;本教程只面向那些个人开发者&#xff0c;想要自己在linux上搭建一个git中央仓库用来上传发布自己的项目。但是对于团队来说可能有更高的要求&#xff0c;可以使用gitlab搭建一个可视化的类似github的版本管理系统测试环境我使用的linux版本是Centos7&#xff0…

linux桌面发展方向,观点|Linux 桌面的发展之路!

Ken Starks 在 fossforce.com 网站上问 你们是如何优化 Linux 的&#xff1f;&#xff0c;我很高兴他问了这个问题&#xff0c;因为我有话要说&#xff01;对我来说&#xff0c;Linux 桌面就是一连串的承诺&#xff0c;但是这些承诺却总是无法兑现。它在每个版本发布后都会说“…

linux常见基础服务,常用的linux命令的基本使用(一)

序号命令对应英文作用01lslist查看当前文件夹下的内容02pwdprint name of of current/working directory查看当前所在文件夹03cd[目录名]change directory切换文件夹04touch[目录名]touch如果文件不存在&#xff0c;新建文件05mkdir[目录名]make directory创建目录06rm[文件名]…

树莓派怎么学linux,树莓派使用入门用树莓派学 Linux

树莓派使用入门用树莓派学 Linux我们的《树莓派使用入门》的第四篇文章将进入到 Linux 命令行。在本系列的 第三篇文章 中开始了我们的树莓派探索之旅&#xff0c;我分享了如何安装 Raspbian&#xff0c;它是树莓派的官方 Linux 版本。现在&#xff0c;你已经安装好了 Raspbian…

全国计算机二级C语言过关要求,计算机二级考试c语言过关经验

计算机二级考试c语言过关经验考试要求考生在规定的时间内按指定的方式解答精心选定的题目或按主办方的要求完成一定的实际操作的任务&#xff0c;并由主办方评定其结果&#xff0c;从而为主办方提供考生某方面的知识或技能状况的信息。下面是小编整理的关于计算机二级考试c语言…

c语言链表贪吃蛇脚本之家,C++控制台实现贪吃蛇游戏

本文实例为大家分享了C实现贪吃蛇游戏的具体代码&#xff0c;供大家参考&#xff0c;具体内容如下刚学完了C语言&#xff0c;便尝试的写了贪吃蛇的代码&#xff0c;但是效果不佳&#xff0c;很多的bug&#xff0c;所以&#xff0c;这个学了C&#xff0c;便重新的写了这个小游戏…