首页 > 学院 > 开发设计 > 正文

迷宫求解最短路径问题java版

2019-11-14 12:33:29
字体:
来源:转载
供稿:网友

对于计算机,面对错乱复杂的迷宫探路问题也不可能一步就找到最优路径,而是把所有可行路径全部走过然后通过比较找出最优路径,对于每走一步都有4个可行方向可走,然后通过循环借助计算机的高效率找出最优路径。代码如下:

public class Maze {//出口目标点坐标PRivate static final int X = 8;private static final int Y = 8;private static final int MaxSize = 200;//迷宫路径int[][] maze = {{1,1,1,1,1,1,1,1,1,1},{1,0,0,1,0,0,0,1,0,1},{1,0,0,1,0,0,0,1,0,1},{1,0,0,0,0,1,1,0,0,1},{1,0,1,1,1,0,0,0,0,1},{1,0,0,0,1,0,0,0,0,1},{1,0,1,0,0,0,1,0,0,1},{1,0,1,1,1,0,1,1,0,1},{1,1,0,0,0,0,0,0,0,1},{1,1,1,1,1,1,1,1,1,1},};Node Stack[] = new Node[MaxSize];Node Path[] = new Node[MaxSize];//栈顶指针int top = -1;//路径的计数int count = 1;//记录最短路径int minlen = MaxSize;public Maze() {System.out.println("路径如下:");mazePath(1,1,X,Y);}//寻路方法public void mazePath(int xi,int yi,int xe,int ye){int i,j,di,find;//初始化栈 起始地点入栈top++;Node n = new Node();Stack[top] = n;System.out.println(Stack[top]);Stack[top].i = xi;Stack[top].j = yi;Stack[top].di = -1;maze[xi][yi] = -1;//如果栈不为空就继续探路while(top>-1){//取出栈顶元素i = Stack[top].i;j = Stack[top].j;di = Stack[top].di;//判断是否已经找到目标点出口  如果找到出口那么打印路径if(i==xe && j ==ye){System.out.println("  "+(count++));for(int k = 0;k <= top;k++){System.out.printf("(%d , %d)",Stack[k].i,Stack[k].j);//每行打印5个坐标点然后换行if((k+1)%5==0){System.out.println("");}}System.out.println("");//找出最短路径  然后赋值给Pathif(top+1 < minlen){minlen = top+1;System.out.println(minlen+"");for(int k = 0;k <= top;k++){Node node = new Node();Path[k] = node;Path[k].i = Stack[k].i;Path[k].j = Stack[k].j;Path[k].di = Stack[k].di;}}//退出一步继续查找可行路径maze[Stack[top].i][Stack[top].j] = 0;top--;i = Stack[top].i;j = Stack[top].j;di = Stack[top].di;}//根据四个方向试探性的查找可行路径find = 0;//用来标记是否已经找到可行路径  0 没找到  1找到while(find==0 && di<4){di++;switch(di){           case 0: i = Stack[top].i-1;j = Stack[top].j;break;           case 1: i = Stack[top].i;j = Stack[top].j+1;break;           case 2: i = Stack[top].i+1;j = Stack[top].j;break;           case 3: i = Stack[top].i;j = Stack[top].j-1;break;           }//如果找到可行路径那么find标记为1if(maze[i][j] == 0){find = 1;}}if(find == 1){//如果找到出口那么进栈Stack[top].di = di;  //进栈前记录当前立脚点的寻路方向top++;Node n1 = new Node();Stack[top] = n1;Stack[top].i = i;Stack[top].j = j;Stack[top].di = -1;//已走过路径标记为-1防止重复路过maze[i][j] = -1;}else{//否则退一步,然后继续试探可行路径maze[Stack[top].i][Stack[top].j] = 0;  //释放路径 为了以后的试探让路top--;}}//一切执行结束后打印最短路径System.out.println("最短路径如下:");System.out.println("最短路径长度:"+minlen);System.out.println("路径:");//打印最短路径for(int k = 0;k < minlen;k++){System.out.printf("(%d , %d)",Path[k].i,Path[k].j);if((k+1)%5 == 0){System.out.println("");}}System.out.println("");}class Node{int i;int j;int di;}public static void main(String[] args) {new Maze();}}


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表