public class City
{
String name;
int id;
static int idCounter = 0;
public City(String name)
{
this.name=name;
id = idCounter++;
}
}
import java.util.ArrayList;

public class Graph {

	public static void main(String[] args)
{
// TODO Auto-generated method stub
Map M = new Map(12);
City a = new City("a");
City b = new City("b");
City c = new City("c");
City d = new City("d");
City e = new City("e");
City f = new City("f");
City g = new City("g");
City h = new City("h");
City i = new City("i");
City j = new City("j");
City k = new City("k");
City l = new City("l"); M.createEdge(a,b,3);
M.createEdge(a,c,5);
M.createEdge(a,d,4); M.createEdge(b,f,6); M.createEdge(c,d,2);
M.createEdge(c,g,4); M.createEdge(d,e,1);
M.createEdge(d,h,5); M.createEdge(e,f,2);
M.createEdge(e,i,4); M.createEdge(f,j,5); M.createEdge(g,h,3);
M.createEdge(g,k,6); M.createEdge(h,i,6);
M.createEdge(h,k,7); M.createEdge(i,j,3);
M.createEdge(i,l,5); M.createEdge(j,l,9); M.createEdge(k,l,8); System.out.println("the graph is:\n");
System.out.println(M); System.out.println();
System.out.println("findPathByDFS:a to k");
M.findPathByDFS(a,k); System.out.println();
System.out.println("findPathByBFS:a to k");
M.findPathByBFS(a,k); System.out.println();
System.out.println("bellmanFord from a:");
M.bellmanFord(a); System.out.println();
System.out.println("dijkstra from a:");
M.dijkstra(a); System.out.println();
System.out.println("bellmanFord,print example from a:");
M.floydWarshall();
M.printFloydWarshallForOneCity(a);
} }
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.Queue; public class Map
{
double[][] A;
public Map(int n)
{
A = new double[n][n];
for(int i = 0;i < A.length;i++)
{
for(int j = 0;j < A.length;j++)
{
if(i == j) A[i][j] = 0;
else A[i][j] = -1;
}
} }
ArrayList<City> cities = new ArrayList<City>(); private double[] D;
private void relax(int u,int v)
{
if(D[v]>D[u]+A[v][u])
D[v]=D[u]+A[v][u];
} private double[][] DD = null;
public void floydWarshall()
{
DD = new double[A.length][A.length];
int i,j,k;
for(i = 0;i < A.length;i++)
{
for(j = 0;j < A.length;j++)
{
if(A[i][j]>0)
DD[i][j] = A[i][j];
else if(i == j) DD[i][j] = 0;
else DD[i][j] = 99999999; }
}
for(k = 0;k < A.length;k++)
for(i = 0;i < A.length;i++)
for(j = 0;j < A.length;j++)
{
if(DD[i][j] > DD[i][k] + DD[k][j])
{
DD[i][j] = DD[i][k] + DD[k][j];
}
}
} public void printFloydWarshallForOneCity(City city)
{
System.out.println("floydWarshall:");
if(DD == null)
{
floydWarshall();
}
for(int i=0;i<A.length;i++)
{
System.out.printf("from %s to %s shortest path is:%f\n",city.name,cities.get(i).name,DD[city.id][i]);
} } public void dijkstra(City city)
{
dijkstra(city.id);
System.out.println("dijkstra:");
for(int i=0;i<A.length;i++)
{
System.out.printf("from %s to %s shortest path is:%f\n", city.name,cities.get(i).name,D[i]);
}
} public void dijkstra(int srcId)
{
D = new double[A.length];
for(int i=0;i<A.length;i++)
{
D[i]=999999999;
}
D[srcId]=0;
int[] q = new int[A.length];
int ql=0,qf=0; //队列 for(int i=0;i<A.length;i++) q[ql++]=i;
while(qf!=ql)
{
int min=qf;
for(int i=qf;i<ql;i++)
{
if(D[q[i]]<D[q[min]])
{
min=i;
}
}
int id = q[qf];
q[qf] = q[min];
q[min] = id; //q[qf] is the min
int u=q[qf++];
for(int i=0;i<A.length;i++)
{
if(A[u][i]>0)
{
relax(u,i);
}
}
}
} public void bellmanFord(City city)
{
bellmanFord(city.id);
System.out.println("bellmanFord:");
for(int i=0;i<A.length;i++)
{
System.out.printf("from %s to %s shortest path is:%f\n", city.name,cities.get(i).name,D[i]);
}
} public void bellmanFord(int srcId)
{
D = new double[A.length];
for(int i=0;i<A.length;i++)
{
D[i] = 99999999;//无穷大
}
D[srcId] = 0;
for(int i=0;i<A.length;i++)//外层循环次数
{
for(int j=0;j<A.length;j++)
{
for(int k=0;k<A.length;k++)
{
if(A[j][k]>0)
{
relax(j,k);
}
}
} }
} Queue<Integer> bfsQueue = new LinkedList<Integer>();
boolean[] bfsFlag;
int bsfPre[];
public void findPathByBFS(City src,City dst)
{
System.out.printf("bfs find path between '%s' and '%s'!\n",src.name,dst.name);
findPathByBFS( src.id, dst.id);
printBFS(dst.id); }
public void findPathByBFS(int srcId,int dstId)
{
bsfPre = new int[A.length];
bfsQueue.clear();
bfsFlag = new boolean[A.length];
for(int i=0;i<A.length;i++)
{
bfsFlag[i] = false;
bsfPre[i] = -1;
} bfsQueue.offer(srcId);
bfsFlag[srcId] = true; while(!bfsQueue.isEmpty())
{
int current = bfsQueue.poll();
for(int index=0;index<A.length;index++)
{
if(current == index) continue;
if(A[current][index]>0) //两者相连
{
if(index == dstId)//找到目标了
{
bfsFlag[index] = true;
bsfPre[index] = current;
return;//直接返回
}
if(bfsFlag[index] == false)//假设未訪问过
{
bfsFlag[index] = true;
bsfPre[index] = current;
bfsQueue.offer(index);
}
} }
} } private void printBFS(int dstId)
{
int index = dstId; do
{
System.out.printf("<-%s", cities.get(index).name);
index = bsfPre[index];
}while(index != -1);
System.out.println();
} ArrayList<Integer> dfsPath = new ArrayList<Integer>();
boolean[] dfsFlag;
private void printDFS()
{
for(Integer node:dfsPath)
{
System.out.printf("->%s", cities.get(node).name);
}
System.out.println();
}
public void findPathByDFS(City src,City dst)
{
System.out.printf("dfs find path between '%s' and '%s'!\n",src.name,dst.name);
findPathByDFS(src.id, dst.id);
}
public void findPathByDFS(int srcId,int dstId)
{
dfsPath.clear();
dfsFlag = new boolean[A.length];
for(int i=0;i<A.length;i++)
{
dfsFlag[i] = false;
}
dfsPath.add(srcId);
dfsFlag[srcId] = true;
dfs( srcId, dstId);
printDFS();
}
private void dfs(int srcId,int dstId)
{
for(int index=0;index<A[srcId].length;index++)
{
if(srcId == index) continue;
if(A[srcId][index]>0)//两者连接
{
if(index == dstId)//找到目标了
{
dfsFlag[index] = true;
dfsPath.add(index);
return;
}
if(dfsFlag[index] == false)//假设该节点未訪问过
{
dfsFlag[index] = true;
dfsPath.add(index);
dfs(index,dstId);
if(dfsFlag[dstId] == false)//目标没找到
dfsPath.remove(index);
else return;
} }
}
} public void createEdge(City a, City b, double w)
{
A[a.id][b.id]=w;
A[b.id][a.id]=w;//added by me!
cities.add(a.id,a);
cities.add(b.id,b);
} public String toString()
{
String r = "I am a map of " + A.length + " cities.";
r += " My connections are:\n";
for (int i=0;i<A.length;i++)
{
for (int j=0;j<A[0].length;j++)
r+=A[i][j]+"\t";
r+="\n";
}
return r;
}
}

经典图算法Java代码实践:BFS,DFS以及几种最短路径算法的更多相关文章

  1. [java代码库]-简易计算器(第二种)

    [java代码库]-简易计算器(第二种) 第二种方案:在程序中不使用if/switch……case等语句,完成计算器功能. <html> <head> <title> ...

  2. python2.7 (x64) 调用 java 代码实践

    背景:公司实施接口自动化测试,使用的框架python+unittest:因为开发使用的架构师SpringBoot,在测试过程中难免需要使用到python调用JAVA的一些接口,所以需要用到python ...

  3. 学习Java绝对要懂的,Java编程中最常用的几种排序算法!

    今天给大家分享一下Java中几种常见的排序算法的Java代码 推荐一下我的Java学习羊君前616,中959,最后444.把数字串联起来!     ,群里有免费的学习视频和项目给大家练手.大神有空时也 ...

  4. [改善Java代码]对字符串排序 持一种宽容的心态

    在Java中一涉及到中文处理就会冒出很多的问题来,其中的排序也是一个让人头疼的问题,看代码: import java.util.Arrays; public class Client { public ...

  5. Java代码模拟http请求的两种方式

    z这里用百度地图的逆地理编码接口为例, 第一种方式:(通过jdk中的java.net包) 引入工具类 import java.net.URL; import java.net.URLConnectio ...

  6. [java代码库]-简易计算器(第一种)

    简易计算器(效果如图所示) 第一种方案:采用Javascript+html完成计算器,支持+-*/,结果显示不允许使用input输入域(可以考虑使用<span>) <html> ...

  7. 阿里官方Java代码规范标准《阿里巴巴Java开发手册 终极版 v1.3.0》

    终极版 v1.3.0 2017年开春之际,阿里诚意献上重磅大礼:<阿里巴巴Java开发手册>,首次公开阿里官方Java代码规范标准.这套Java统一规范标准将有助于提高行业编码规范化水平, ...

  8. 阿里官方Java代码规范标准《阿里巴巴Java开发手册》下载

    https://bbs.aliyun.com/read/306592.html?page=e 2017年开春之际,诚意献上重磅大礼:阿里巴巴Java开发手册,首次公开阿里官方Java代码规范标准. 这 ...

  9. Spring Boot 使用Java代码创建Bean并注册到Spring中

    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/catoop/article/details/50558333 声明同一个类下的多个实例: packa ...

随机推荐

  1. 安装mongodb插件

    1.安装mngodb模块 wget http://pecl.php.net/get/mongodb-1.2.4.tgz tar zxf mongodb-1.2.4.tgz cd mongodb-1.2 ...

  2. [COGS2479 && COGS2639]高维偏序(CDQ分治,bitset)

    COGS2479:四维偏序. CDQ套CDQ CDQ:对a分治,对b排序,再对a打标记,然后执行CDQ2 CDQ2:对b分治,对c归并排序,对d树状数组. #include<cstdio> ...

  3. POJ 2975 Nim(博弈论)

    [题目链接] http://poj.org/problem?id=2975 [题目大意] 问在传统的nim游戏中先手必胜策略的数量 [题解] 设sg=a1^a1^a3^a4^………^an,当sg为0时 ...

  4. 【分块】【哈希】bzoj3578 GTY的人类基因组计划2

    每个房间用一个集合来维护,具体来说,就是给1-n的数每个数一个long long的hash值,往集合S里insert(i),就是S^=HASH[i]:erase(i),也是S^=HASH[i]. 用m ...

  5. 【权值分块】bzoj1503 [NOI2004]郁闷的出纳员

    权值分块,离散化非常蛋疼,只能离散化搞…… 需要支持操作:删除<=某个值得所有权值==打标记 O(sqrt(n)) 码长和我的平衡树差不多……速度快3倍左右. #include<cstdi ...

  6. 千克与磅之间的转换 Exercise05_05

    /** * @author 冰樱梦 * 时间:2018年下半年 * 题目:千克与磅之间的转换 * */ public class Exercise05_05 { public static void ...

  7. Spring整合jdbc-jdbc模板api详解

    1, package com.songyan.jdbc2; public class User { private int id; private String name; public int ge ...

  8. 在WinRT程序中使用MEF

    今天试了一下在WinRT中使用MEF,这里简单的介绍一下步骤. 首先,使用NuGet安装MEF 然后,就可以使用MEF组装插件了,简单的示例如下: interface ILogger    {     ...

  9. Oracle审计--AUD$占用空间较大处理方案

    Oracle 11G以后,数据库默认是开启审计功能的,因此有时候我们忘记了关闭该功能导致SYSTEM表空间暴满,但由于关闭审计功能需要重启数据库,此类操作生产环境下是不允许的,因此我们需要找出哪类审计 ...

  10. 排查java.lang.OutOfMemoryError: GC overhead limit exceeded

    帮助客户排查java.lang.OutOfMemoryError: GC overhead limit exceeded错误记录: 具体网址: https://support.oracle.com/e ...