H5+JAVA实现最短路径算法与地图显示(第三天)

本贴最后更新于 3148 天前,其中的信息可能已经时异事殊

再说下算法部分。

我参考了网上的一些算法。采用到的是 floyd算法。参考地址http://www.ddvip.com/tech/1000140659.html

嫌弃它广告太多,我还是把图抠过来了,如下:

算法实例

 

再顺路搬一段文字过来:

初始状态:S是记录各个顶点间最短路径的矩阵。 
第1步:初始化S。 
     矩阵S中顶点a[i][j]的距离为顶点i到顶点j的权值;如果i和j不相邻,则a[i][j]=∞。实际上,就是将图的原始矩阵复制到S中。 
     注:a[i][j]表示矩阵S中顶点i(第i个顶点)到顶点j(第j个顶点)的距离。  

第2步:以顶点A(第1个顶点)为中介点,若a[i][j] > a[i][0]+a[0][j],则设置a[i][j]=a[i][0]+a[0][j]。 
     以顶点a[1]6,上一步操作之后,a[1][6]=∞;而将A作为中介点时,(B,A)=12,(A,G)=14,因此B和G之间的距离可以更新为26。  

同理,依次将顶点B,C,D,E,F,G作为中介点,并更新a[i][j]的大小。

好了,算法的核心也就出来了,一直更新一个矩阵。

那么先来定义一些变量吧:

private static final int INF = Integer.MAX_VALUE;   // 最大值,处理两点之间无线断的权值。
int pointNum=points.size();
int n=pointNum;//总点数,从数据读取的
int path[][]=new int[n+1][n+1];//路径矩阵,记录点的前驱
int map[][]=new int[pointNum+1][pointNum+1];//构造权值矩阵
int dist[][]=map;//最终的最短路径矩阵 其实也可以之间用map

接下来是核心算法代码:

//算法算出所有点对点最短路径
for(int k=1; k<=n; k++) {
    for(int i=1; i<=n; i++) {
	for(int j=1; j<=n; j++) {
           // 如果经过下标为k顶点路径比原两点间路径更短,则更新dist[i][j]和path[i][j]
	  if(!(dist[i][k]==INF||dist[k][j]==INF)&&dist[i][j] > dist[i][k] + dist[k][j]) {
		 dist[i][j] = dist[i][k] + dist[k][j];
		 // "i到j最短路径"对应的路径,经过k
		 path[i][k] = i;
		 path[i][j] = path[k][j];
		   }
	    }

}
}

 

 

最终的写在后台的控制器的代码为:

@RequestMapping(value = "/test",produces="application/json;charset=utf-8", method = {RequestMethod.POST,RequestMethod.GET})
			public @ResponseBody JSONObject test(HttpSession session,
					@RequestParam(required = false) int from,
					@RequestParam(required = false) int to)
			{
					JSONObject obj=new JSONObject();
//					找到所有的点
					PointDAO pdao=new PointDAOImpl();
					LineDAO ldao=new LineDAOImpl();
					List<Point> points=pdao.findAllPoint();
					int pointNum=points.size();
					int n=pointNum;//总点数,从数据读取的
					int path[][]=new int[n+1][n+1];//路径矩阵,记录点的前驱
					int map[][]=new int[pointNum+1][pointNum+1];//构造权值矩阵
//					读取数据库,赋初值
					for(int i=1;i<=pointNum;i++) {
						for(int j=1;j<=pointNum;j++) {
							Line line=ldao.find(i, j);
								if(i==j) {
									map[i][j]=0;//自己到自己距离为0
								}
								else if(line==null) {//不存在此路径,权值为无穷大
									map[i][j]=INF;
								}
								else {
									map[i][j]=line.getLenth(); 
								}
						}
					}
//					打印输入的矩阵,便于控制台查看
					System.out.println("打印输入的矩阵");
					for(int i=1;i<=pointNum;i++) {
						for(int j=1;j<=pointNum;j++) {
							System.out.print(map[i][j]+"|");
						}
						System.out.println("");
					}
//					定义路径前驱
					int dist[][]=map;//最终的最短路径矩阵
				    for(int i=1; i<=n ; i++){
				        for(int j=1; j<= n; j++){
				          if(map[i][j]==0){
				               path[i][j] = -1;//表示  i -> j 不通 
				          }else{
				               path[i][j] = i;// 表示 i -> j 前驱为 i
				          }
				        }
				      }
//				    算法算出所有点对点最短路径
				    for(int k=1; k<=n; k++) {
				        for(int i=1; i<=n; i++) {
				          for(int j=1; j<=n; j++) {
				        	  // 如果经过下标为k顶点路径比原两点间路径更短,则更新dist[i][j]和path[i][j]
				            if(!(dist[i][k]==INF||dist[k][j]==INF)&&dist[i][j] > dist[i][k] + dist[k][j]) {
				              dist[i][j] = dist[i][k] + dist[k][j];
				              // "i到j最短路径"对应的路径,经过k
				              path[i][k] = i;
				              path[i][j] = path[k][j];
				            }
				          }
			        }
			      }
			    System.out.println("打印最终的矩阵");
			    for(int i=1;i&lt;=n;i++) {
					for(int j=1;j&lt;=n;j++) {
						System.out.print(dist[i][j]+"|");
					}
					System.out.println("");
				}
			    obj.put("lenth", dist[from][to]);

// 倒序输出
List<Point> p=new ArrayList<Point>();
p.add(pdao.find(to));
while(path[from][to]!=from) {
System.out.print(path[from][to] +"----");
p.add(pdao.find(path[from][to]));
to = path[from][to];
}
p.add(pdao.find(from));
Collections.reverse(p);

			    obj.put("path", p);
			return obj;
		}</pre>

 

前台传过来两个参数,起始点和终结点,算法算出这两个点的最短路径以及经过的点,然后将结果存入JSONObject对象,传给前台。

下面是前台ajax请求的代码部分:

jQuery(document).on('click', ".searchPath", function() {
			var data={
				from:$("#searchFrom").val(),
				to:$("#searchTo").val()
			}
			jQuery.ajax({
				type: 'POST',
				 url: "test",
				 data:data,
				 dataType: 'json',
				 success: function(json) { 
					 var canvers=document.getElementById('mycanver');
						var cxt=canvers.getContext('2d');
								cxt.save(); 
								cxt.strokeStyle="red";
								cxt.translate(0.5,0.5); 
								cxt.lineWidth = 2; 
								cxt.beginPath(); 
								cxt.moveTo(json.path[0].x, json.path[0].y); 
								var text="最短路径为:"+json.path[0].name;
								for(var i=1;i<json.path.length;i++){
									cxt.lineTo(json.path[i].x,json.path[i].y);
									text=text+"——>"+json.path[i].name;
								}
								$("#control").html(text+"\<br\>");
								$("#control").append("最短路径为:"+json.lenth+"米\<br\>");
								$("#control").append("步行大约用时:"+Math.ceil(json.lenth/60)+"分钟")
								cxt.stroke(); 
								cxt.restore(); 
						}
				});
		 });

差不多了就缺整体代码了,最后再更新。

 

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • WordPress

    WordPress 是一个使用 PHP 语言开发的博客平台,用户可以在支持 PHP 和 MySQL 数据库的服务器上架设自己的博客。也可以把 WordPress 当作一个内容管理系统(CMS)来使用。WordPress 是一个免费的开源项目,在 GNU 通用公共许可证(GPLv2)下授权发布。

    45 引用 • 113 回帖 • 306 关注
  • Firefox

    Mozilla Firefox 中文俗称“火狐”(正式缩写为 Fx 或 fx,非正式缩写为 FF),是一个开源的网页浏览器,使用 Gecko 排版引擎,支持多种操作系统,如 Windows、OSX 及 Linux 等。

    7 引用 • 30 回帖 • 449 关注
  • OpenResty

    OpenResty 是一个基于 NGINX 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。

    17 引用 • 40 关注
  • Gitea

    Gitea 是一个开源社区驱动的轻量级代码托管解决方案,后端采用 Go 编写,采用 MIT 许可证。

    4 引用 • 16 回帖 • 2 关注
  • 阿里巴巴

    阿里巴巴网络技术有限公司(简称:阿里巴巴集团)是以曾担任英语教师的马云为首的 18 人,于 1999 年在中国杭州创立,他们相信互联网能够创造公平的竞争环境,让小企业通过创新与科技扩展业务,并在参与国内或全球市场竞争时处于更有利的位置。

    43 引用 • 221 回帖 • 237 关注
  • 微服务

    微服务架构是一种架构模式,它提倡将单一应用划分成一组小的服务。服务之间互相协调,互相配合,为用户提供最终价值。每个服务运行在独立的进程中。服务于服务之间才用轻量级的通信机制互相沟通。每个服务都围绕着具体业务构建,能够被独立的部署。

    96 引用 • 155 回帖 • 3 关注
  • 快应用

    快应用 是基于手机硬件平台的新型应用形态;标准是由主流手机厂商组成的快应用联盟联合制定;快应用标准的诞生将在研发接口、能力接入、开发者服务等层面建设标准平台;以平台化的生态模式对个人开发者和企业开发者全品类开放。

    15 引用 • 127 回帖 • 4 关注
  • 导航

    各种网址链接、内容导航。

    37 引用 • 168 回帖
  • Angular

    AngularAngularJS 的新版本。

    26 引用 • 66 回帖 • 509 关注
  • Wide

    Wide 是一款基于 Web 的 Go 语言 IDE。通过浏览器就可以进行 Go 开发,并有代码自动完成、查看表达式、编译反馈、Lint、实时结果输出等功能。

    欢迎访问我们运维的实例: https://wide.b3log.org

    30 引用 • 218 回帖 • 603 关注
  • Webswing

    Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用

    1 引用 • 15 回帖 • 635 关注
  • Quicker

    Quicker 您的指尖工具箱!操作更少,收获更多!

    20 引用 • 74 回帖
  • Ubuntu

    Ubuntu(友帮拓、优般图、乌班图)是一个以桌面应用为主的 Linux 操作系统,其名称来自非洲南部祖鲁语或豪萨语的“ubuntu”一词,意思是“人性”、“我的存在是因为大家的存在”,是非洲传统的一种价值观,类似华人社会的“仁爱”思想。Ubuntu 的目标在于为一般用户提供一个最新的、同时又相当稳定的主要由自由软件构建而成的操作系统。

    123 引用 • 168 回帖
  • 新人

    让我们欢迎这对新人。哦,不好意思说错了,让我们欢迎这位新人!
    新手上路,请谨慎驾驶!

    51 引用 • 226 回帖
  • Swagger

    Swagger 是一款非常流行的 API 开发工具,它遵循 OpenAPI Specification(这是一种通用的、和编程语言无关的 API 描述规范)。Swagger 贯穿整个 API 生命周期,如 API 的设计、编写文档、测试和部署。

    26 引用 • 35 回帖 • 13 关注
  • 机器学习

    机器学习(Machine Learning)是一门多领域交叉学科,涉及概率论、统计学、逼近论、凸分析、算法复杂度理论等多门学科。专门研究计算机怎样模拟或实现人类的学习行为,以获取新的知识或技能,重新组织已有的知识结构使之不断改善自身的性能。

    76 引用 • 37 回帖 • 1 关注
  • 微信

    腾讯公司 2011 年 1 月 21 日推出的一款手机通讯软件。用户可以通过摇一摇、搜索号码、扫描二维码等添加好友和关注公众平台,同时可以将自己看到的精彩内容分享到微信朋友圈。

    129 引用 • 793 回帖
  • 笔记

    好记性不如烂笔头。

    305 引用 • 780 回帖
  • InfluxDB

    InfluxDB 是一个开源的没有外部依赖的时间序列数据库。适用于记录度量,事件及实时分析。

    2 引用 • 53 关注
  • FFmpeg

    FFmpeg 是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。

    22 引用 • 31 回帖 • 2 关注
  • 深度学习

    深度学习(Deep Learning)是机器学习的分支,是一种试图使用包含复杂结构或由多重非线性变换构成的多个处理层对数据进行高层抽象的算法。

    40 引用 • 40 回帖
  • Git

    Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

    205 引用 • 357 回帖
  • 小薇

    小薇是一个用 Java 写的 QQ 聊天机器人 Web 服务,可以用于社群互动。

    由于 Smart QQ 从 2019 年 1 月 1 日起停止服务,所以该项目也已经停止维护了!

    34 引用 • 467 回帖 • 691 关注
  • Facebook

    Facebook 是一个联系朋友的社交工具。大家可以通过它和朋友、同事、同学以及周围的人保持互动交流,分享无限上传的图片,发布链接和视频,更可以增进对朋友的了解。

    4 引用 • 15 回帖 • 455 关注
  • SSL

    SSL(Secure Sockets Layer 安全套接层),及其继任者传输层安全(Transport Layer Security,TLS)是为网络通信提供安全及数据完整性的一种安全协议。TLS 与 SSL 在传输层对网络连接进行加密。

    69 引用 • 190 回帖 • 494 关注
  • C

    C 语言是一门通用计算机编程语言,应用广泛。C 语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。

    83 引用 • 165 回帖 • 40 关注
  • LaTeX

    LaTeX(音译“拉泰赫”)是一种基于 ΤΕΧ 的排版系统,由美国计算机学家莱斯利·兰伯特(Leslie Lamport)在 20 世纪 80 年代初期开发,利用这种格式,即使使用者没有排版和程序设计的知识也可以充分发挥由 TeX 所提供的强大功能,能在几天,甚至几小时内生成很多具有书籍质量的印刷品。对于生成复杂表格和数学公式,这一点表现得尤为突出。因此它非常适用于生成高印刷质量的科技和数学类文档。

    9 引用 • 32 回帖 • 158 关注