跳马(华为od机考题)

打印 上一主题 下一主题

主题 967|帖子 967|积分 2901

一、题目

1.原题

马是象棋(包罗中国象棋和国际象棋)中的棋子,
走法是每步直一格再斜一格,
即先横着或直着走一格,然后再斜着走一个对角线,
可进可退,可越过河界,俗称“马走‘日’字。
给顶m行n列的棋盘(网格图),
棋盘上只有有棋子象棋中的棋子“马”,
而且每个棋子有品级之分,
品级为k的马可以跳1~k步
(走的方式与象棋中“马”的规则一样,不可以超出棋盘位置),
问是否能将全部马跳到同一位置,
如果存在,输出最少需要的总步数(每匹马的步数相加),
不存在则输出-1。
注:允许不同的马在跳的过程中跳到同一位置,
坐标为(x,y)的马跳一次可以跳到到坐标为
(x+1, y+2),  (x+1, y-2), 
(x+2, y+1), (x+2, y-1), 
(x-1, y+2), (x-1, y-2), 
(x-2, y+1), (x-2, y-1),
的格点上,但是不可以超出棋盘范围。

2.题目理解


马的移动规则:先横着或直着走一格,然后再斜着走一个对角线
即每一步(x±1/2,y±2/2)

二、思路与代码过程

1.思路

每一匹马给一个board,用于记录它抵达棋盘某位置的所用步数,全部的马的board构成boards,对board进行比较即可。
2.代码过程

①main函数

  1. public static  void main(String[] args) {
  2.         /*
  3.         Scanner sc = new Scanner(System.in);
  4.         System.out.println("请输入棋盘行数m:");
  5.         int m = sc.nextInt();
  6.         System.out.println("请输入棋盘列数n:");
  7.         int n = sc.nextInt();
  8.         System.out.println("请输入马在棋盘上的分布:");
  9.         int[][] horses = new int[m][n];
  10.         for (int i = 0; i < m; i++) {
  11.             for (int j = 0; j < n; j++) {
  12.                 horses[i][j] = sc.nextInt();
  13.             }
  14.         }
  15.         sc.close();
  16.         System.out.println(Arrays.deepToString(horses));
  17.         */
  18.         int m = 4;
  19.         int n = 4;
  20.         int[][] horse = {{1,9,9,7},{0,3,0,6},{2,0,0,2},{1,0,3,0}};
  21.         ArrayList<Horse> horses = turnToHorse(horse);
  22.         int minStep = searhEachHorse(horses,m,n);
  23.         if (minStep==-1){
  24.             System.out.println("不能将所有马跳到同一位置");
  25.         }else {
  26.             System.out.println("能将所有马跳到同一位置,且最少需要的总步数为:"+minStep);
  27.         }
  28.     }
复制代码
②searhEachHorse

  1. private static int searhEachHorse(ArrayList<Horse> horses, int m, int n) {
  2.         //每一匹马的位置和步数board组成所有马的boards
  3.         ArrayList<int[][]> boards = new ArrayList<>();
  4.         for (int i = 0; i < horses.size(); i++) {//每一匹马
  5.             //先看一匹
  6.             //for (int i = 1; i < 2; i++) {
  7.                 Horse horse = horses.get(i);
  8.             if (horse.k!=0){
  9.                 //每一匹马都给个board,存的是每个位置所需要的步数step(step根据k算出每个位置的最小步数!)
  10.                 int[][] board = new int[m][n];
  11.                 int[][] boardk = new int[m][n];
  12.                 int k =horse.k;//跳步级别
  13.                 System.out.println("\n"+i+"---------searchEachHorse---------");
  14.                 System.out.print("当前马为:"+horse.toString());
  15.                 int[] horseZk = horse.getPostion();
  16.                 int[][] visit = new int[m][n];
  17.                 int[][] visited;
  18.                 Queue<int[]> q = new LinkedList<>();//要随调用传值
  19.                 q.add(horseZk);
  20.                 int[][] box = new int[m][n];//传值
  21.                 int level = 0;
  22.                 board = findPostion(horse,m,n,visit,q,box,level);//找完位置返回含有step信息的board
  23.                 boardk = boardCal(board,k);
  24.                 System.out.println("--===board-k===--");
  25.                 for (int[] row : board) {
  26.                     System.out.println(Arrays.toString(row));
  27.                 }
  28.                 boards.add(boardk);
  29.                 System.out.println(i+"---------searchEachHorseFinished---------\n");
  30.             }
  31.         }
  32.         //获得了所有马在棋盘上的位置和步数信息
  33.         for (int[][] board : boards) {
  34.             for (int[] row : board) {
  35.                 System.out.print(Arrays.toString(row)+"\n");
  36.             }
  37.             System.out.println();
  38.         }
  39.         int totalStep = CheckBoards(m,n,boards);
  40.         return totalStep;
  41.     }
复制代码
③CheckBoards

  1. private static int CheckBoards(int m,int n,ArrayList<int[][]> boards) {
  2.         System.out.println("---------checkBoard---------");
  3.         int totalSteps = 0 ;
  4.         int[][] exist = new int[m][n];
  5.         boolean allCanArr = true;
  6.         for (int i = 0; i < m; i++) {
  7.             Arrays.fill(exist[i], 1); // 填充每一行
  8.         }//默认都存在
  9.         int[][] AddStep = new int[m][n];
  10.         for (int i = 0; i <m; i++) {
  11.             for (int j = 0; j < n; j++) {
  12.                 int addSteps = 0;
  13.                 for (int k = 0; k < boards.size(); k++) {
  14.                     //System.out.println(boards.get(k)[i][j]);
  15.                     if (boards.get(k)[i][j] == 0) {//检验是否存在有马到不了的位置
  16.                         exist[i][j] = 0;
  17.                     }
  18.                     addSteps += boards.get(k)[i][j];
  19.                 }
  20.                 AddStep[i][j] = addSteps;
  21.             }
  22.         }
  23.         for (int[] row : AddStep) {
  24.             for (int val : row) {
  25.                 if (val == 1) {
  26.                     allCanArr = false;
  27.                 }
  28.             }
  29.             System.out.println(Arrays.toString(row));
  30.         }
  31.         for (int[] existBoard : exist) {
  32.             System.out.println(Arrays.toString(existBoard));
  33.         }
  34.         int minStep = Integer.MAX_VALUE;
  35.         for (int i = 0; i < m; i++) {
  36.             for (int j = 0; j <n; j++) {
  37.                 minStep = Math.min(minStep,AddStep[i][j]);
  38.             }
  39.         }
  40.         totalSteps = minStep;
  41.         System.out.println(totalSteps);
  42.         if (allCanArr) {
  43.             return totalSteps;
  44.         }else{
  45.             return -1;
  46.         }
  47.     }
复制代码
④boardCal

  1. private static int[][] boardCal(int[][] board, int k) {
  2.         int[][] boardk = new int[board.length][board[0].length];
  3.         for (int i = 0; i < board.length; i++) {
  4.             for (int j = 0; j < board[0].length; j++) {
  5.                 boardk[i][j] = board[i][j];
  6.                 if (boardk[i][j] <= k&&boardk[i][j] !=-1) {//=============================2
  7.                     boardk[i][j]= 1;
  8.                 } else if (boardk[i][j] > k) {
  9.                     /*小于:eg:k=2,step=5=2+2+1,step=7=2+2+2+1*/
  10.                     int r = board[i][j]%k;
  11.                     if (r==0){
  12.                         boardk[i][j] =board[i][j]/k;
  13.                     }else {
  14.                         boardk[i][j] = board[i][j]/k+ 1;
  15.                     }
  16.                 }
  17.             }
  18.         }
  19.         for (int[] row : boardk) {
  20.             System.out.println(Arrays.toString(row));
  21.         }
  22.         return boardk;
  23.     }
复制代码
⑤turnToHorse

  1. private static ArrayList<Horse> turnToHorse(int[][] horse) {
  2.         ArrayList<Horse> horses = new ArrayList<>();
  3.         for (int i = 0; i < horse.length; i++) {
  4.             for (int j = 0; j < horse[i].length; j++) {
  5.                 int[] postion =new int[2];
  6.                 int k = 0;
  7.                 postion[0] = i;
  8.                 postion[1] = j;
  9.                 k = horse[i][j];
  10.                 horses.add(new Horse(postion,k,0,0));
  11.             }
  12.         }
  13.         return horses;
  14.     }
复制代码
⑥方向数组

  1. static int[][] DIRECTION={{1,2},{1,-2},
  2.             {2,1},{2,-1},
  3.             {-1,2},{-1,-2},
  4.             {-2,1},{-2,-1}};
复制代码
⑦findPosition

  1. static ArrayList<int[]> postions = new ArrayList<>();//协助观察
  2.     private static int[][] findPostion(Horse horse,int m,int n,int[][] visit,Queue<int[]> q,int[][]box,int level ) {
  3.         //变化量:step、level注意传值
  4.         int k = horse.k;
  5.         System.out.println("k:"+k);
  6.         box[horse.postion[0]][horse.postion[1]] = -1;//=============================1
  7.         while (!q.isEmpty()) {
  8.             //队列中遍历
  9.             int[] temp = q.poll();
  10.             visit[temp[0]][temp[1]] = 1;
  11.             ///*
  12.             System.out.println("到当前马"+Arrays.toString(temp)+"的访问列表:");
  13.             for (int[] row : visit) {
  14.                 System.out.println(Arrays.toString(row));
  15.             }
  16.             if (Arrays.stream(visit)
  17.                     .flatMapToInt(Arrays::stream) // 将二维数组扁平化为一维流
  18.                     .allMatch(value -> value == 1)){
  19.                 return visit;
  20.             }
  21.            // */
  22.             System.out.println("-------findPostion-------");
  23.             int size = q.size();
  24.             System.out.println("加之前q的大小:"+size);
  25.             for (int[] direction : DIRECTION) {
  26.                 int x = temp[0]+ direction[0];
  27.                 int y = temp[1] + direction[1];
  28.                 //System.out.println("("+x+","+y+")");
  29.                 int[] Z = {x,y};
  30.                 boolean contains = false;
  31.                 for (int[] currentArray : q) {
  32.                     if (Arrays.equals(currentArray, Z)) {
  33.                         contains = true; // 找到相同的数组
  34.                     }
  35.                 }
  36.                 if (x>=0&&x<n&&y>=0&&y<m&&visit[x][y]==0&&!contains) {//只加入没去过的点
  37.                     postions.add(Z);//协助观察
  38.                     q.add(Z);
  39.                 }
  40.             }
  41.             int size1 = q.size();
  42.             System.out.println("加之后q的大小:"+size1);
  43.             System.out.println("到前马"+Arrays.toString(temp)+"时的q队列:");
  44.             int newadd = size1 - size;
  45.             System.out.println("新增了:"+newadd+"个元素");
  46.             /*写到这里了,层级的自增!!!!!!!!!*/
  47.             if(newadd>0){
  48.                 level++;
  49.             }
  50.             List<int[]> list = new ArrayList<>(q);
  51.             for (int i = size1-1; i >=size; i--) {
  52.                 box[list.get(i)[0]][list.get(i)[1]] = level;
  53.             }
  54.             System.out.println("===box===");
  55.             for (int[] row : box) {
  56.                 System.out.println(Arrays.toString(row));
  57.             }
  58.             for (int[] element : q) {
  59.                 System.out.println(Arrays.toString(element));
  60.             }
  61.             findPostion(horse,m,n,visit,q,box,level);
  62.         }
  63.         //return visit;
  64.         return box;
  65.     }
复制代码
⑧Horse类(可不建)

  1. public static class Horse{
  2.         int[] postion;
  3.         int k;
  4.         int level;
  5.         int step;
  6.         public Horse(int[] postion, int k, int level,int step) {
  7.             this.postion = postion;
  8.             this.k = k;
  9.             this.level = level;
  10.             this.step = step;
  11.         }
  12.         public String toString(){
  13.             return "坐标:["+postion[0]+","+postion[1]+"],等级:"+k+",当前层级:"+level+"当前步数:"+step+"\n";
  14.         }
  15.         public int getK(){
  16.             return k;
  17.         }
  18.         public int getLevel(){
  19.             return level;
  20.         }
  21.         public int[] getPostion(){
  22.             return postion;
  23.         }
  24.     }
复制代码
三、运行效果

1.运行截图


2.带数据分析运行效果

0---------searchEachHorse---------
当前马为:坐标:[0,0],品级:1,当前层级:0当前步数:0
k:1
到当前马[0, 0]的访问列表:
[1, 0, 0, 0]
[0, 0, 0, 0]
[0, 0, 0, 0]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:0
加之后q的巨细:2
到前马[0, 0]时的q队列:
新增了:2个元素
===box===
[-1, 0, 0, 0]
[0, 0, 1, 0]
[0, 1, 0, 0]
[0, 0, 0, 0]
[1, 2]
[2, 1]
k:1
到当前马[1, 2]的访问列表:
[1, 0, 0, 0]
[0, 0, 1, 0]
[0, 0, 0, 0]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:1
加之后q的巨细:4
到前马[1, 2]时的q队列:
新增了:3个元素
===box===
[-1, 0, 0, 0]
[0, 0, 1, 0]
[2, 1, 0, 0]
[0, 2, 0, 2]
[2, 1]
[2, 0]
[3, 3]
[3, 1]
k:1
到当前马[2, 1]的访问列表:
[1, 0, 0, 0]
[0, 0, 1, 0]
[0, 1, 0, 0]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:5
到前马[2, 1]时的q队列:
新增了:2个元素
===box===
[-1, 0, 3, 0]
[0, 0, 1, 3]
[2, 1, 0, 0]
[0, 2, 0, 2]
[2, 0]
[3, 3]
[3, 1]
[1, 3]
[0, 2]
k:1
到当前马[2, 0]的访问列表:
[1, 0, 0, 0]
[0, 0, 1, 0]
[1, 1, 0, 0]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:6
到前马[2, 0]时的q队列:
新增了:2个元素
===box===
[-1, 4, 3, 0]
[0, 0, 1, 3]
[2, 1, 0, 0]
[0, 2, 4, 2]
[3, 3]
[3, 1]
[1, 3]
[0, 2]
[3, 2]
[0, 1]
k:1
到当前马[3, 3]的访问列表:
[1, 0, 0, 0]
[0, 0, 1, 0]
[1, 1, 0, 0]
[0, 0, 0, 1]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:5
到前马[3, 3]时的q队列:
新增了:0个元素
===box===
[-1, 4, 3, 0]
[0, 0, 1, 3]
[2, 1, 0, 0]
[0, 2, 4, 2]
[3, 1]
[1, 3]
[0, 2]
[3, 2]
[0, 1]
k:1
到当前马[3, 1]的访问列表:
[1, 0, 0, 0]
[0, 0, 1, 0]
[1, 1, 0, 0]
[0, 1, 0, 1]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:6
到前马[3, 1]时的q队列:
新增了:2个元素
===box===
[-1, 4, 3, 0]
[5, 0, 1, 3]
[2, 1, 0, 5]
[0, 2, 4, 2]
[1, 3]
[0, 2]
[3, 2]
[0, 1]
[2, 3]
[1, 0]
k:1
到当前马[1, 3]的访问列表:
[1, 0, 0, 0]
[0, 0, 1, 1]
[1, 1, 0, 0]
[0, 1, 0, 1]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:5
到前马[1, 3]时的q队列:
新增了:0个元素
===box===
[-1, 4, 3, 0]
[5, 0, 1, 3]
[2, 1, 0, 5]
[0, 2, 4, 2]
[0, 2]
[3, 2]
[0, 1]
[2, 3]
[1, 0]
k:1
到当前马[0, 2]的访问列表:
[1, 0, 1, 0]
[0, 0, 1, 1]
[1, 1, 0, 0]
[0, 1, 0, 1]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:4
到前马[0, 2]时的q队列:
新增了:0个元素
===box===
[-1, 4, 3, 0]
[5, 0, 1, 3]
[2, 1, 0, 5]
[0, 2, 4, 2]
[3, 2]
[0, 1]
[2, 3]
[1, 0]
k:1
到当前马[3, 2]的访问列表:
[1, 0, 1, 0]
[0, 0, 1, 1]
[1, 1, 0, 0]
[0, 1, 1, 1]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:4
到前马[3, 2]时的q队列:
新增了:1个元素
===box===
[-1, 4, 3, 0]
[5, 6, 1, 3]
[2, 1, 0, 5]
[0, 2, 4, 2]
[0, 1]
[2, 3]
[1, 0]
[1, 1]
k:1
到当前马[0, 1]的访问列表:
[1, 1, 1, 0]
[0, 0, 1, 1]
[1, 1, 0, 0]
[0, 1, 1, 1]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:4
到前马[0, 1]时的q队列:
新增了:1个元素
===box===
[-1, 4, 3, 0]
[5, 6, 1, 3]
[2, 1, 7, 5]
[0, 2, 4, 2]
[2, 3]
[1, 0]
[1, 1]
[2, 2]
k:1
到当前马[2, 3]的访问列表:
[1, 1, 1, 0]
[0, 0, 1, 1]
[1, 1, 0, 1]
[0, 1, 1, 1]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:3
到前马[2, 3]时的q队列:
新增了:0个元素
===box===
[-1, 4, 3, 0]
[5, 6, 1, 3]
[2, 1, 7, 5]
[0, 2, 4, 2]
[1, 0]
[1, 1]
[2, 2]
k:1
到当前马[1, 0]的访问列表:
[1, 1, 1, 0]
[1, 0, 1, 1]
[1, 1, 0, 1]
[0, 1, 1, 1]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:2
到前马[1, 0]时的q队列:
新增了:0个元素
===box===
[-1, 4, 3, 0]
[5, 6, 1, 3]
[2, 1, 7, 5]
[0, 2, 4, 2]
[1, 1]
[2, 2]
k:1
到当前马[1, 1]的访问列表:
[1, 1, 1, 0]
[1, 1, 1, 1]
[1, 1, 0, 1]
[0, 1, 1, 1]
-------findPostion-------
加之前q的巨细:1
加之后q的巨细:3
到前马[1, 1]时的q队列:
新增了:2个元素
===box===
[-1, 4, 3, 8]
[5, 6, 1, 3]
[2, 1, 7, 5]
[8, 2, 4, 2]
[2, 2]
[3, 0]
[0, 3]
k:1
到当前马[2, 2]的访问列表:
[1, 1, 1, 0]
[1, 1, 1, 1]
[1, 1, 1, 1]
[0, 1, 1, 1]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:2
到前马[2, 2]时的q队列:
新增了:0个元素
===box===
[-1, 4, 3, 8]
[5, 6, 1, 3]
[2, 1, 7, 5]
[8, 2, 4, 2]
[3, 0]
[0, 3]
k:1
到当前马[3, 0]的访问列表:
[1, 1, 1, 0]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
-------findPostion-------
加之前q的巨细:1
加之后q的巨细:1
到前马[3, 0]时的q队列:
新增了:0个元素
===box===
[-1, 4, 3, 8]
[5, 6, 1, 3]
[2, 1, 7, 5]
[8, 2, 4, 2]
[0, 3]
k:1
到当前马[0, 3]的访问列表:
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[-1, 4, 3, 8]
[5, 6, 1, 3]
[2, 1, 7, 5]
[8, 2, 4, 2]
--===board-k===--
[-1, 4, 3, 8]
[5, 6, 1, 3]
[2, 1, 7, 5]
[8, 2, 4, 2]
0---------searchEachHorseFinished---------

1---------searchEachHorse---------
当前马为:坐标:[0,1],品级:9,当前层级:0当前步数:0
k:9
到当前马[0, 1]的访问列表:
[0, 1, 0, 0]
[0, 0, 0, 0]
[0, 0, 0, 0]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:0
加之后q的巨细:3
到前马[0, 1]时的q队列:
新增了:3个元素
===box===
[0, -1, 0, 0]
[0, 0, 0, 1]
[1, 0, 1, 0]
[0, 0, 0, 0]
[1, 3]
[2, 2]
[2, 0]
k:9
到当前马[1, 3]的访问列表:
[0, 1, 0, 0]
[0, 0, 0, 1]
[0, 0, 0, 0]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:4
到前马[1, 3]时的q队列:
新增了:2个元素
===box===
[0, -1, 0, 0]
[0, 0, 0, 1]
[1, 2, 1, 0]
[0, 0, 2, 0]
[2, 2]
[2, 0]
[2, 1]
[3, 2]
k:9
到当前马[2, 2]的访问列表:
[0, 1, 0, 0]
[0, 0, 0, 1]
[0, 0, 1, 0]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:6
到前马[2, 2]时的q队列:
新增了:3个元素
===box===
[0, -1, 0, 3]
[3, 0, 0, 1]
[1, 2, 1, 0]
[3, 0, 2, 0]
[2, 0]
[2, 1]
[3, 2]
[3, 0]
[1, 0]
[0, 3]
k:9
到当前马[2, 0]的访问列表:
[0, 1, 0, 0]
[0, 0, 0, 1]
[1, 0, 1, 0]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:6
到前马[2, 0]时的q队列:
新增了:1个元素
===box===
[0, -1, 0, 3]
[3, 0, 4, 1]
[1, 2, 1, 0]
[3, 0, 2, 0]
[2, 1]
[3, 2]
[3, 0]
[1, 0]
[0, 3]
[1, 2]
k:9
到当前马[2, 1]的访问列表:
[0, 1, 0, 0]
[0, 0, 0, 1]
[1, 1, 1, 0]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:8
到前马[2, 1]时的q队列:
新增了:3个元素
===box===
[5, -1, 5, 3]
[3, 0, 4, 1]
[1, 2, 1, 0]
[3, 0, 2, 5]
[3, 2]
[3, 0]
[1, 0]
[0, 3]
[1, 2]
[3, 3]
[0, 2]
[0, 0]
k:9
到当前马[3, 2]的访问列表:
[0, 1, 0, 0]
[0, 0, 0, 1]
[1, 1, 1, 0]
[0, 0, 1, 0]
-------findPostion-------
加之前q的巨细:7
加之后q的巨细:8
到前马[3, 2]时的q队列:
新增了:1个元素
===box===
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 0]
[3, 0, 2, 5]
[3, 0]
[1, 0]
[0, 3]
[1, 2]
[3, 3]
[0, 2]
[0, 0]
[1, 1]
k:9
到当前马[3, 0]的访问列表:
[0, 1, 0, 0]
[0, 0, 0, 1]
[1, 1, 1, 0]
[1, 0, 1, 0]
-------findPostion-------
加之前q的巨细:7
加之后q的巨细:7
到前马[3, 0]时的q队列:
新增了:0个元素
===box===
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 0]
[3, 0, 2, 5]
[1, 0]
[0, 3]
[1, 2]
[3, 3]
[0, 2]
[0, 0]
[1, 1]
k:9
到当前马[1, 0]的访问列表:
[0, 1, 0, 0]
[1, 0, 0, 1]
[1, 1, 1, 0]
[1, 0, 1, 0]
-------findPostion-------
加之前q的巨细:6
加之后q的巨细:7
到前马[1, 0]时的q队列:
新增了:1个元素
===box===
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 0]
[3, 7, 2, 5]
[0, 3]
[1, 2]
[3, 3]
[0, 2]
[0, 0]
[1, 1]
[3, 1]
k:9
到当前马[0, 3]的访问列表:
[0, 1, 0, 1]
[1, 0, 0, 1]
[1, 1, 1, 0]
[1, 0, 1, 0]
-------findPostion-------
加之前q的巨细:6
加之后q的巨细:6
到前马[0, 3]时的q队列:
新增了:0个元素
===box===
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 0]
[3, 7, 2, 5]
[1, 2]
[3, 3]
[0, 2]
[0, 0]
[1, 1]
[3, 1]
k:9
到当前马[1, 2]的访问列表:
[0, 1, 0, 1]
[1, 0, 1, 1]
[1, 1, 1, 0]
[1, 0, 1, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:5
到前马[1, 2]时的q队列:
新增了:0个元素
===box===
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 0]
[3, 7, 2, 5]
[3, 3]
[0, 2]
[0, 0]
[1, 1]
[3, 1]
k:9
到当前马[3, 3]的访问列表:
[0, 1, 0, 1]
[1, 0, 1, 1]
[1, 1, 1, 0]
[1, 0, 1, 1]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:4
到前马[3, 3]时的q队列:
新增了:0个元素
===box===
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 0]
[3, 7, 2, 5]
[0, 2]
[0, 0]
[1, 1]
[3, 1]
k:9
到当前马[0, 2]的访问列表:
[0, 1, 1, 1]
[1, 0, 1, 1]
[1, 1, 1, 0]
[1, 0, 1, 1]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:4
到前马[0, 2]时的q队列:
新增了:1个元素
===box===
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 8]
[3, 7, 2, 5]
[0, 0]
[1, 1]
[3, 1]
[2, 3]
k:9
到当前马[0, 0]的访问列表:
[1, 1, 1, 1]
[1, 0, 1, 1]
[1, 1, 1, 0]
[1, 0, 1, 1]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:3
到前马[0, 0]时的q队列:
新增了:0个元素
===box===
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 8]
[3, 7, 2, 5]
[1, 1]
[3, 1]
[2, 3]
k:9
到当前马[1, 1]的访问列表:
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 0]
[1, 0, 1, 1]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:2
到前马[1, 1]时的q队列:
新增了:0个元素
===box===
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 8]
[3, 7, 2, 5]
[3, 1]
[2, 3]
k:9
到当前马[3, 1]的访问列表:
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 0]
[1, 1, 1, 1]
-------findPostion-------
加之前q的巨细:1
加之后q的巨细:1
到前马[3, 1]时的q队列:
新增了:0个元素
===box===
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 8]
[3, 7, 2, 5]
[2, 3]
k:9
到当前马[2, 3]的访问列表:
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, -1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
--===board-k===--
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 8]
[3, 7, 2, 5]
1---------searchEachHorseFinished---------

2---------searchEachHorse---------
当前马为:坐标:[0,2],品级:9,当前层级:0当前步数:0
k:9
到当前马[0, 2]的访问列表:
[0, 0, 1, 0]
[0, 0, 0, 0]
[0, 0, 0, 0]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:0
加之后q的巨细:3
到前马[0, 2]时的q队列:
新增了:3个元素
===box===
[0, 0, -1, 0]
[1, 0, 0, 0]
[0, 1, 0, 1]
[0, 0, 0, 0]
[1, 0]
[2, 3]
[2, 1]
k:9
到当前马[1, 0]的访问列表:
[0, 0, 1, 0]
[1, 0, 0, 0]
[0, 0, 0, 0]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:4
到前马[1, 0]时的q队列:
新增了:2个元素
===box===
[0, 0, -1, 0]
[1, 0, 0, 0]
[0, 1, 2, 1]
[0, 2, 0, 0]
[2, 3]
[2, 1]
[2, 2]
[3, 1]
k:9
到当前马[2, 3]的访问列表:
[0, 0, 1, 0]
[1, 0, 0, 0]
[0, 0, 0, 1]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:4
到前马[2, 3]时的q队列:
新增了:1个元素
===box===
[0, 0, -1, 0]
[1, 3, 0, 0]
[0, 1, 2, 1]
[0, 2, 0, 0]
[2, 1]
[2, 2]
[3, 1]
[1, 1]
k:9
到当前马[2, 1]的访问列表:
[0, 0, 1, 0]
[1, 0, 0, 0]
[0, 1, 0, 1]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:6
到前马[2, 1]时的q队列:
新增了:3个元素
===box===
[4, 0, -1, 0]
[1, 3, 0, 4]
[0, 1, 2, 1]
[0, 2, 0, 4]
[2, 2]
[3, 1]
[1, 1]
[3, 3]
[1, 3]
[0, 0]
k:9
到当前马[2, 2]的访问列表:
[0, 0, 1, 0]
[1, 0, 0, 0]
[0, 1, 1, 1]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:8
到前马[2, 2]时的q队列:
新增了:3个元素
===box===
[4, 5, -1, 5]
[1, 3, 0, 4]
[0, 1, 2, 1]
[5, 2, 0, 4]
[3, 1]
[1, 1]
[3, 3]
[1, 3]
[0, 0]
[3, 0]
[0, 3]
[0, 1]
k:9
到当前马[3, 1]的访问列表:
[0, 0, 1, 0]
[1, 0, 0, 0]
[0, 1, 1, 1]
[0, 1, 0, 0]
-------findPostion-------
加之前q的巨细:7
加之后q的巨细:8
到前马[3, 1]时的q队列:
新增了:1个元素
===box===
[4, 5, -1, 5]
[1, 3, 6, 4]
[0, 1, 2, 1]
[5, 2, 0, 4]
[1, 1]
[3, 3]
[1, 3]
[0, 0]
[3, 0]
[0, 3]
[0, 1]
[1, 2]
k:9
到当前马[1, 1]的访问列表:
[0, 0, 1, 0]
[1, 1, 0, 0]
[0, 1, 1, 1]
[0, 1, 0, 0]
-------findPostion-------
加之前q的巨细:7
加之后q的巨细:8
到前马[1, 1]时的q队列:
新增了:1个元素
===box===
[4, 5, -1, 5]
[1, 3, 6, 4]
[0, 1, 2, 1]
[5, 2, 7, 4]
[3, 3]
[1, 3]
[0, 0]
[3, 0]
[0, 3]
[0, 1]
[1, 2]
[3, 2]
k:9
到当前马[3, 3]的访问列表:
[0, 0, 1, 0]
[1, 1, 0, 0]
[0, 1, 1, 1]
[0, 1, 0, 1]
-------findPostion-------
加之前q的巨细:7
加之后q的巨细:7
到前马[3, 3]时的q队列:
新增了:0个元素
===box===
[4, 5, -1, 5]
[1, 3, 6, 4]
[0, 1, 2, 1]
[5, 2, 7, 4]
[1, 3]
[0, 0]
[3, 0]
[0, 3]
[0, 1]
[1, 2]
[3, 2]
k:9
到当前马[1, 3]的访问列表:
[0, 0, 1, 0]
[1, 1, 0, 1]
[0, 1, 1, 1]
[0, 1, 0, 1]
-------findPostion-------
加之前q的巨细:6
加之后q的巨细:6
到前马[1, 3]时的q队列:
新增了:0个元素
===box===
[4, 5, -1, 5]
[1, 3, 6, 4]
[0, 1, 2, 1]
[5, 2, 7, 4]
[0, 0]
[3, 0]
[0, 3]
[0, 1]
[1, 2]
[3, 2]
k:9
到当前马[0, 0]的访问列表:
[1, 0, 1, 0]
[1, 1, 0, 1]
[0, 1, 1, 1]
[0, 1, 0, 1]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:5
到前马[0, 0]时的q队列:
新增了:0个元素
===box===
[4, 5, -1, 5]
[1, 3, 6, 4]
[0, 1, 2, 1]
[5, 2, 7, 4]
[3, 0]
[0, 3]
[0, 1]
[1, 2]
[3, 2]
k:9
到当前马[3, 0]的访问列表:
[1, 0, 1, 0]
[1, 1, 0, 1]
[0, 1, 1, 1]
[1, 1, 0, 1]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:4
到前马[3, 0]时的q队列:
新增了:0个元素
===box===
[4, 5, -1, 5]
[1, 3, 6, 4]
[0, 1, 2, 1]
[5, 2, 7, 4]
[0, 3]
[0, 1]
[1, 2]
[3, 2]
k:9
到当前马[0, 3]的访问列表:
[1, 0, 1, 1]
[1, 1, 0, 1]
[0, 1, 1, 1]
[1, 1, 0, 1]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:3
到前马[0, 3]时的q队列:
新增了:0个元素
===box===
[4, 5, -1, 5]
[1, 3, 6, 4]
[0, 1, 2, 1]
[5, 2, 7, 4]
[0, 1]
[1, 2]
[3, 2]
k:9
到当前马[0, 1]的访问列表:
[1, 1, 1, 1]
[1, 1, 0, 1]
[0, 1, 1, 1]
[1, 1, 0, 1]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:3
到前马[0, 1]时的q队列:
新增了:1个元素
===box===
[4, 5, -1, 5]
[1, 3, 6, 4]
[8, 1, 2, 1]
[5, 2, 7, 4]
[1, 2]
[3, 2]
[2, 0]
k:9
到当前马[1, 2]的访问列表:
[1, 1, 1, 1]
[1, 1, 1, 1]
[0, 1, 1, 1]
[1, 1, 0, 1]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:2
到前马[1, 2]时的q队列:
新增了:0个元素
===box===
[4, 5, -1, 5]
[1, 3, 6, 4]
[8, 1, 2, 1]
[5, 2, 7, 4]
[3, 2]
[2, 0]
k:9
到当前马[3, 2]的访问列表:
[1, 1, 1, 1]
[1, 1, 1, 1]
[0, 1, 1, 1]
[1, 1, 1, 1]
-------findPostion-------
加之前q的巨细:1
加之后q的巨细:1
到前马[3, 2]时的q队列:
新增了:0个元素
===box===
[4, 5, -1, 5]
[1, 3, 6, 4]
[8, 1, 2, 1]
[5, 2, 7, 4]
[2, 0]
k:9
到当前马[2, 0]的访问列表:
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, -1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
--===board-k===--
[4, 5, -1, 5]
[1, 3, 6, 4]
[8, 1, 2, 1]
[5, 2, 7, 4]
2---------searchEachHorseFinished---------

3---------searchEachHorse---------
当前马为:坐标:[0,3],品级:7,当前层级:0当前步数:0
k:7
到当前马[0, 3]的访问列表:
[0, 0, 0, 1]
[0, 0, 0, 0]
[0, 0, 0, 0]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:0
加之后q的巨细:2
到前马[0, 3]时的q队列:
新增了:2个元素
===box===
[0, 0, 0, -1]
[0, 1, 0, 0]
[0, 0, 1, 0]
[0, 0, 0, 0]
[1, 1]
[2, 2]
k:7
到当前马[1, 1]的访问列表:
[0, 0, 0, 1]
[0, 1, 0, 0]
[0, 0, 0, 0]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:1
加之后q的巨细:4
到前马[1, 1]时的q队列:
新增了:3个元素
===box===
[0, 0, 0, -1]
[0, 1, 0, 0]
[0, 0, 1, 2]
[2, 0, 2, 0]
[2, 2]
[2, 3]
[3, 2]
[3, 0]
k:7
到当前马[2, 2]的访问列表:
[0, 0, 0, 1]
[0, 1, 0, 0]
[0, 0, 1, 0]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:5
到前马[2, 2]时的q队列:
新增了:2个元素
===box===
[0, 3, 0, -1]
[3, 1, 0, 0]
[0, 0, 1, 2]
[2, 0, 2, 0]
[2, 3]
[3, 2]
[3, 0]
[1, 0]
[0, 1]
k:7
到当前马[2, 3]的访问列表:
[0, 0, 0, 1]
[0, 1, 0, 0]
[0, 0, 1, 1]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:6
到前马[2, 3]时的q队列:
新增了:2个元素
===box===
[0, 3, 4, -1]
[3, 1, 0, 0]
[0, 0, 1, 2]
[2, 4, 2, 0]
[3, 2]
[3, 0]
[1, 0]
[0, 1]
[3, 1]
[0, 2]
k:7
到当前马[3, 2]的访问列表:
[0, 0, 0, 1]
[0, 1, 0, 0]
[0, 0, 1, 1]
[0, 0, 1, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:7
到前马[3, 2]时的q队列:
新增了:2个元素
===box===
[0, 3, 4, -1]
[3, 1, 0, 5]
[5, 0, 1, 2]
[2, 4, 2, 0]
[3, 0]
[1, 0]
[0, 1]
[3, 1]
[0, 2]
[2, 0]
[1, 3]
k:7
到当前马[3, 0]的访问列表:
[0, 0, 0, 1]
[0, 1, 0, 0]
[0, 0, 1, 1]
[1, 0, 1, 0]
-------findPostion-------
加之前q的巨细:6
加之后q的巨细:6
到前马[3, 0]时的q队列:
新增了:0个元素
===box===
[0, 3, 4, -1]
[3, 1, 0, 5]
[5, 0, 1, 2]
[2, 4, 2, 0]
[1, 0]
[0, 1]
[3, 1]
[0, 2]
[2, 0]
[1, 3]
k:7
到当前马[1, 0]的访问列表:
[0, 0, 0, 1]
[1, 1, 0, 0]
[0, 0, 1, 1]
[1, 0, 1, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:5
到前马[1, 0]时的q队列:
新增了:0个元素
===box===
[0, 3, 4, -1]
[3, 1, 0, 5]
[5, 0, 1, 2]
[2, 4, 2, 0]
[0, 1]
[3, 1]
[0, 2]
[2, 0]
[1, 3]
k:7
到当前马[0, 1]的访问列表:
[0, 1, 0, 1]
[1, 1, 0, 0]
[0, 0, 1, 1]
[1, 0, 1, 0]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:4
到前马[0, 1]时的q队列:
新增了:0个元素
===box===
[0, 3, 4, -1]
[3, 1, 0, 5]
[5, 0, 1, 2]
[2, 4, 2, 0]
[3, 1]
[0, 2]
[2, 0]
[1, 3]
k:7
到当前马[3, 1]的访问列表:
[0, 1, 0, 1]
[1, 1, 0, 0]
[0, 0, 1, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:4
到前马[3, 1]时的q队列:
新增了:1个元素
===box===
[0, 3, 4, -1]
[3, 1, 6, 5]
[5, 0, 1, 2]
[2, 4, 2, 0]
[0, 2]
[2, 0]
[1, 3]
[1, 2]
k:7
到当前马[0, 2]的访问列表:
[0, 1, 1, 1]
[1, 1, 0, 0]
[0, 0, 1, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:4
到前马[0, 2]时的q队列:
新增了:1个元素
===box===
[0, 3, 4, -1]
[3, 1, 6, 5]
[5, 7, 1, 2]
[2, 4, 2, 0]
[2, 0]
[1, 3]
[1, 2]
[2, 1]
k:7
到当前马[2, 0]的访问列表:
[0, 1, 1, 1]
[1, 1, 0, 0]
[1, 0, 1, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:3
到前马[2, 0]时的q队列:
新增了:0个元素
===box===
[0, 3, 4, -1]
[3, 1, 6, 5]
[5, 7, 1, 2]
[2, 4, 2, 0]
[1, 3]
[1, 2]
[2, 1]
k:7
到当前马[1, 3]的访问列表:
[0, 1, 1, 1]
[1, 1, 0, 1]
[1, 0, 1, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:2
到前马[1, 3]时的q队列:
新增了:0个元素
===box===
[0, 3, 4, -1]
[3, 1, 6, 5]
[5, 7, 1, 2]
[2, 4, 2, 0]
[1, 2]
[2, 1]
k:7
到当前马[1, 2]的访问列表:
[0, 1, 1, 1]
[1, 1, 1, 1]
[1, 0, 1, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:1
加之后q的巨细:3
到前马[1, 2]时的q队列:
新增了:2个元素
===box===
[8, 3, 4, -1]
[3, 1, 6, 5]
[5, 7, 1, 2]
[2, 4, 2, 8]
[2, 1]
[3, 3]
[0, 0]
k:7
到当前马[2, 1]的访问列表:
[0, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:2
到前马[2, 1]时的q队列:
新增了:0个元素
===box===
[8, 3, 4, -1]
[3, 1, 6, 5]
[5, 7, 1, 2]
[2, 4, 2, 8]
[3, 3]
[0, 0]
k:7
到当前马[3, 3]的访问列表:
[0, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
-------findPostion-------
加之前q的巨细:1
加之后q的巨细:1
到前马[3, 3]时的q队列:
新增了:0个元素
===box===
[8, 3, 4, -1]
[3, 1, 6, 5]
[5, 7, 1, 2]
[2, 4, 2, 8]
[0, 0]
k:7
到当前马[0, 0]的访问列表:
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[2, 1, 1, -1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 2]
--===board-k===--
[8, 3, 4, -1]
[3, 1, 6, 5]
[5, 7, 1, 2]
[2, 4, 2, 8]
3---------searchEachHorseFinished---------

5---------searchEachHorse---------
当前马为:坐标:[1,1],品级:3,当前层级:0当前步数:0
k:3
到当前马[1, 1]的访问列表:
[0, 0, 0, 0]
[0, 1, 0, 0]
[0, 0, 0, 0]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:0
加之后q的巨细:4
到前马[1, 1]时的q队列:
新增了:4个元素
===box===
[0, 0, 0, 1]
[0, -1, 0, 0]
[0, 0, 0, 1]
[1, 0, 1, 0]
[2, 3]
[3, 2]
[3, 0]
[0, 3]
k:3
到当前马[2, 3]的访问列表:
[0, 0, 0, 0]
[0, 1, 0, 0]
[0, 0, 0, 1]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:5
到前马[2, 3]时的q队列:
新增了:2个元素
===box===
[0, 0, 2, 1]
[0, -1, 0, 0]
[0, 0, 0, 1]
[1, 2, 1, 0]
[3, 2]
[3, 0]
[0, 3]
[3, 1]
[0, 2]
k:3
到当前马[3, 2]的访问列表:
[0, 0, 0, 0]
[0, 1, 0, 0]
[0, 0, 0, 1]
[0, 0, 1, 0]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:6
到前马[3, 2]时的q队列:
新增了:2个元素
===box===
[0, 0, 2, 1]
[0, -1, 0, 3]
[3, 0, 0, 1]
[1, 2, 1, 0]
[3, 0]
[0, 3]
[3, 1]
[0, 2]
[2, 0]
[1, 3]
k:3
到当前马[3, 0]的访问列表:
[0, 0, 0, 0]
[0, 1, 0, 0]
[0, 0, 0, 1]
[1, 0, 1, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:6
到前马[3, 0]时的q队列:
新增了:1个元素
===box===
[0, 0, 2, 1]
[0, -1, 0, 3]
[3, 0, 4, 1]
[1, 2, 1, 0]
[0, 3]
[3, 1]
[0, 2]
[2, 0]
[1, 3]
[2, 2]
k:3
到当前马[0, 3]的访问列表:
[0, 0, 0, 1]
[0, 1, 0, 0]
[0, 0, 0, 1]
[1, 0, 1, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:5
到前马[0, 3]时的q队列:
新增了:0个元素
===box===
[0, 0, 2, 1]
[0, -1, 0, 3]
[3, 0, 4, 1]
[1, 2, 1, 0]
[3, 1]
[0, 2]
[2, 0]
[1, 3]
[2, 2]
k:3
到当前马[3, 1]的访问列表:
[0, 0, 0, 1]
[0, 1, 0, 0]
[0, 0, 0, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:6
到前马[3, 1]时的q队列:
新增了:2个元素
===box===
[0, 0, 2, 1]
[5, -1, 5, 3]
[3, 0, 4, 1]
[1, 2, 1, 0]
[0, 2]
[2, 0]
[1, 3]
[2, 2]
[1, 2]
[1, 0]
k:3
到当前马[0, 2]的访问列表:
[0, 0, 1, 1]
[0, 1, 0, 0]
[0, 0, 0, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:6
到前马[0, 2]时的q队列:
新增了:1个元素
===box===
[0, 0, 2, 1]
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 0]
[2, 0]
[1, 3]
[2, 2]
[1, 2]
[1, 0]
[2, 1]
k:3
到当前马[2, 0]的访问列表:
[0, 0, 1, 1]
[0, 1, 0, 0]
[1, 0, 0, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:6
到前马[2, 0]时的q队列:
新增了:1个元素
===box===
[0, 7, 2, 1]
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 0]
[1, 3]
[2, 2]
[1, 2]
[1, 0]
[2, 1]
[0, 1]
k:3
到当前马[1, 3]的访问列表:
[0, 0, 1, 1]
[0, 1, 0, 1]
[1, 0, 0, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:5
到前马[1, 3]时的q队列:
新增了:0个元素
===box===
[0, 7, 2, 1]
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 0]
[2, 2]
[1, 2]
[1, 0]
[2, 1]
[0, 1]
k:3
到当前马[2, 2]的访问列表:
[0, 0, 1, 1]
[0, 1, 0, 1]
[1, 0, 1, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:4
到前马[2, 2]时的q队列:
新增了:0个元素
===box===
[0, 7, 2, 1]
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 0]
[1, 2]
[1, 0]
[2, 1]
[0, 1]
k:3
到当前马[1, 2]的访问列表:
[0, 0, 1, 1]
[0, 1, 1, 1]
[1, 0, 1, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:5
到前马[1, 2]时的q队列:
新增了:2个元素
===box===
[8, 7, 2, 1]
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 8]
[1, 0]
[2, 1]
[0, 1]
[3, 3]
[0, 0]
k:3
到当前马[1, 0]的访问列表:
[0, 0, 1, 1]
[1, 1, 1, 1]
[1, 0, 1, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:4
到前马[1, 0]时的q队列:
新增了:0个元素
===box===
[8, 7, 2, 1]
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 8]
[2, 1]
[0, 1]
[3, 3]
[0, 0]
k:3
到当前马[2, 1]的访问列表:
[0, 0, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:3
到前马[2, 1]时的q队列:
新增了:0个元素
===box===
[8, 7, 2, 1]
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 8]
[0, 1]
[3, 3]
[0, 0]
k:3
到当前马[0, 1]的访问列表:
[0, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:2
到前马[0, 1]时的q队列:
新增了:0个元素
===box===
[8, 7, 2, 1]
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 8]
[3, 3]
[0, 0]
k:3
到当前马[3, 3]的访问列表:
[0, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
-------findPostion-------
加之前q的巨细:1
加之后q的巨细:1
到前马[3, 3]时的q队列:
新增了:0个元素
===box===
[8, 7, 2, 1]
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 8]
[0, 0]
k:3
到当前马[0, 0]的访问列表:
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[3, 3, 1, 1]
[2, -1, 2, 1]
[1, 2, 2, 1]
[1, 1, 1, 3]
--===board-k===--
[8, 7, 2, 1]
[5, -1, 5, 3]
[3, 6, 4, 1]
[1, 2, 1, 8]
5---------searchEachHorseFinished---------

7---------searchEachHorse---------
当前马为:坐标:[1,3],品级:6,当前层级:0当前步数:0
k:6
到当前马[1, 3]的访问列表:
[0, 0, 0, 0]
[0, 0, 0, 1]
[0, 0, 0, 0]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:0
加之后q的巨细:3
到前马[1, 3]时的q队列:
新增了:3个元素
===box===
[0, 1, 0, 0]
[0, 0, 0, -1]
[0, 1, 0, 0]
[0, 0, 1, 0]
[2, 1]
[3, 2]
[0, 1]
k:6
到当前马[2, 1]的访问列表:
[0, 0, 0, 0]
[0, 0, 0, 1]
[0, 1, 0, 0]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:5
到前马[2, 1]时的q队列:
新增了:3个元素
===box===
[2, 1, 2, 0]
[0, 0, 0, -1]
[0, 1, 0, 0]
[0, 0, 1, 2]
[3, 2]
[0, 1]
[3, 3]
[0, 2]
[0, 0]
k:6
到当前马[3, 2]的访问列表:
[0, 0, 0, 0]
[0, 0, 0, 1]
[0, 1, 0, 0]
[0, 0, 1, 0]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:6
到前马[3, 2]时的q队列:
新增了:2个元素
===box===
[2, 1, 2, 0]
[0, 3, 0, -1]
[3, 1, 0, 0]
[0, 0, 1, 2]
[0, 1]
[3, 3]
[0, 2]
[0, 0]
[2, 0]
[1, 1]
k:6
到当前马[0, 1]的访问列表:
[0, 1, 0, 0]
[0, 0, 0, 1]
[0, 1, 0, 0]
[0, 0, 1, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:6
到前马[0, 1]时的q队列:
新增了:1个元素
===box===
[2, 1, 2, 0]
[0, 3, 0, -1]
[3, 1, 4, 0]
[0, 0, 1, 2]
[3, 3]
[0, 2]
[0, 0]
[2, 0]
[1, 1]
[2, 2]
k:6
到当前马[3, 3]的访问列表:
[0, 1, 0, 0]
[0, 0, 0, 1]
[0, 1, 0, 0]
[0, 0, 1, 1]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:6
到前马[3, 3]时的q队列:
新增了:1个元素
===box===
[2, 1, 2, 0]
[0, 3, 5, -1]
[3, 1, 4, 0]
[0, 0, 1, 2]
[0, 2]
[0, 0]
[2, 0]
[1, 1]
[2, 2]
[1, 2]
k:6
到当前马[0, 2]的访问列表:
[0, 1, 1, 0]
[0, 0, 0, 1]
[0, 1, 0, 0]
[0, 0, 1, 1]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:7
到前马[0, 2]时的q队列:
新增了:2个元素
===box===
[2, 1, 2, 0]
[6, 3, 5, -1]
[3, 1, 4, 6]
[0, 0, 1, 2]
[0, 0]
[2, 0]
[1, 1]
[2, 2]
[1, 2]
[1, 0]
[2, 3]
k:6
到当前马[0, 0]的访问列表:
[1, 1, 1, 0]
[0, 0, 0, 1]
[0, 1, 0, 0]
[0, 0, 1, 1]
-------findPostion-------
加之前q的巨细:6
加之后q的巨细:6
到前马[0, 0]时的q队列:
新增了:0个元素
===box===
[2, 1, 2, 0]
[6, 3, 5, -1]
[3, 1, 4, 6]
[0, 0, 1, 2]
[2, 0]
[1, 1]
[2, 2]
[1, 2]
[1, 0]
[2, 3]
k:6
到当前马[2, 0]的访问列表:
[1, 1, 1, 0]
[0, 0, 0, 1]
[1, 1, 0, 0]
[0, 0, 1, 1]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:5
到前马[2, 0]时的q队列:
新增了:0个元素
===box===
[2, 1, 2, 0]
[6, 3, 5, -1]
[3, 1, 4, 6]
[0, 0, 1, 2]
[1, 1]
[2, 2]
[1, 2]
[1, 0]
[2, 3]
k:6
到当前马[1, 1]的访问列表:
[1, 1, 1, 0]
[0, 1, 0, 1]
[1, 1, 0, 0]
[0, 0, 1, 1]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:6
到前马[1, 1]时的q队列:
新增了:2个元素
===box===
[2, 1, 2, 7]
[6, 3, 5, -1]
[3, 1, 4, 6]
[7, 0, 1, 2]
[2, 2]
[1, 2]
[1, 0]
[2, 3]
[3, 0]
[0, 3]
k:6
到当前马[2, 2]的访问列表:
[1, 1, 1, 0]
[0, 1, 0, 1]
[1, 1, 1, 0]
[0, 0, 1, 1]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:5
到前马[2, 2]时的q队列:
新增了:0个元素
===box===
[2, 1, 2, 7]
[6, 3, 5, -1]
[3, 1, 4, 6]
[7, 0, 1, 2]
[1, 2]
[1, 0]
[2, 3]
[3, 0]
[0, 3]
k:6
到当前马[1, 2]的访问列表:
[1, 1, 1, 0]
[0, 1, 1, 1]
[1, 1, 1, 0]
[0, 0, 1, 1]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:5
到前马[1, 2]时的q队列:
新增了:1个元素
===box===
[2, 1, 2, 7]
[6, 3, 5, -1]
[3, 1, 4, 6]
[7, 8, 1, 2]
[1, 0]
[2, 3]
[3, 0]
[0, 3]
[3, 1]
k:6
到当前马[1, 0]的访问列表:
[1, 1, 1, 0]
[1, 1, 1, 1]
[1, 1, 1, 0]
[0, 0, 1, 1]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:4
到前马[1, 0]时的q队列:
新增了:0个元素
===box===
[2, 1, 2, 7]
[6, 3, 5, -1]
[3, 1, 4, 6]
[7, 8, 1, 2]
[2, 3]
[3, 0]
[0, 3]
[3, 1]
k:6
到当前马[2, 3]的访问列表:
[1, 1, 1, 0]
[1, 1, 1, 1]
[1, 1, 1, 1]
[0, 0, 1, 1]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:3
到前马[2, 3]时的q队列:
新增了:0个元素
===box===
[2, 1, 2, 7]
[6, 3, 5, -1]
[3, 1, 4, 6]
[7, 8, 1, 2]
[3, 0]
[0, 3]
[3, 1]
k:6
到当前马[3, 0]的访问列表:
[1, 1, 1, 0]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 0, 1, 1]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:2
到前马[3, 0]时的q队列:
新增了:0个元素
===box===
[2, 1, 2, 7]
[6, 3, 5, -1]
[3, 1, 4, 6]
[7, 8, 1, 2]
[0, 3]
[3, 1]
k:6
到当前马[0, 3]的访问列表:
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 0, 1, 1]
-------findPostion-------
加之前q的巨细:1
加之后q的巨细:1
到前马[0, 3]时的q队列:
新增了:0个元素
===box===
[2, 1, 2, 7]
[6, 3, 5, -1]
[3, 1, 4, 6]
[7, 8, 1, 2]
[3, 1]
k:6
到当前马[3, 1]的访问列表:
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 2]
[1, 1, 1, -1]
[1, 1, 1, 1]
[2, 2, 1, 1]
--===board-k===--
[2, 1, 2, 7]
[6, 3, 5, -1]
[3, 1, 4, 6]
[7, 8, 1, 2]
7---------searchEachHorseFinished---------

8---------searchEachHorse---------
当前马为:坐标:[2,0],品级:2,当前层级:0当前步数:0
k:2
到当前马[2, 0]的访问列表:
[0, 0, 0, 0]
[0, 0, 0, 0]
[1, 0, 0, 0]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:0
加之后q的巨细:3
到前马[2, 0]时的q队列:
新增了:3个元素
===box===
[0, 1, 0, 0]
[0, 0, 1, 0]
[-1, 0, 0, 0]
[0, 0, 1, 0]
[3, 2]
[1, 2]
[0, 1]
k:2
到当前马[3, 2]的访问列表:
[0, 0, 0, 0]
[0, 0, 0, 0]
[1, 0, 0, 0]
[0, 0, 1, 0]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:4
到前马[3, 2]时的q队列:
新增了:2个元素
===box===
[0, 1, 0, 0]
[0, 2, 1, 2]
[-1, 0, 0, 0]
[0, 0, 1, 0]
[1, 2]
[0, 1]
[1, 3]
[1, 1]
k:2
到当前马[1, 2]的访问列表:
[0, 0, 0, 0]
[0, 0, 1, 0]
[1, 0, 0, 0]
[0, 0, 1, 0]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:6
到前马[1, 2]时的q队列:
新增了:3个元素
===box===
[3, 1, 0, 0]
[0, 2, 1, 2]
[-1, 0, 0, 0]
[0, 3, 1, 3]
[0, 1]
[1, 3]
[1, 1]
[3, 3]
[3, 1]
[0, 0]
k:2
到当前马[0, 1]的访问列表:
[0, 1, 0, 0]
[0, 0, 1, 0]
[1, 0, 0, 0]
[0, 0, 1, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:6
到前马[0, 1]时的q队列:
新增了:1个元素
===box===
[3, 1, 0, 0]
[0, 2, 1, 2]
[-1, 0, 4, 0]
[0, 3, 1, 3]
[1, 3]
[1, 1]
[3, 3]
[3, 1]
[0, 0]
[2, 2]
k:2
到当前马[1, 3]的访问列表:
[0, 1, 0, 0]
[0, 0, 1, 1]
[1, 0, 0, 0]
[0, 0, 1, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:6
到前马[1, 3]时的q队列:
新增了:1个元素
===box===
[3, 1, 0, 0]
[0, 2, 1, 2]
[-1, 5, 4, 0]
[0, 3, 1, 3]
[1, 1]
[3, 3]
[3, 1]
[0, 0]
[2, 2]
[2, 1]
k:2
到当前马[1, 1]的访问列表:
[0, 1, 0, 0]
[0, 1, 1, 1]
[1, 0, 0, 0]
[0, 0, 1, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:8
到前马[1, 1]时的q队列:
新增了:3个元素
===box===
[3, 1, 0, 6]
[0, 2, 1, 2]
[-1, 5, 4, 6]
[6, 3, 1, 3]
[3, 3]
[3, 1]
[0, 0]
[2, 2]
[2, 1]
[2, 3]
[3, 0]
[0, 3]
k:2
到当前马[3, 3]的访问列表:
[0, 1, 0, 0]
[0, 1, 1, 1]
[1, 0, 0, 0]
[0, 0, 1, 1]
-------findPostion-------
加之前q的巨细:7
加之后q的巨细:7
到前马[3, 3]时的q队列:
新增了:0个元素
===box===
[3, 1, 0, 6]
[0, 2, 1, 2]
[-1, 5, 4, 6]
[6, 3, 1, 3]
[3, 1]
[0, 0]
[2, 2]
[2, 1]
[2, 3]
[3, 0]
[0, 3]
k:2
到当前马[3, 1]的访问列表:
[0, 1, 0, 0]
[0, 1, 1, 1]
[1, 0, 0, 0]
[0, 1, 1, 1]
-------findPostion-------
加之前q的巨细:6
加之后q的巨细:7
到前马[3, 1]时的q队列:
新增了:1个元素
===box===
[3, 1, 0, 6]
[7, 2, 1, 2]
[-1, 5, 4, 6]
[6, 3, 1, 3]
[0, 0]
[2, 2]
[2, 1]
[2, 3]
[3, 0]
[0, 3]
[1, 0]
k:2
到当前马[0, 0]的访问列表:
[1, 1, 0, 0]
[0, 1, 1, 1]
[1, 0, 0, 0]
[0, 1, 1, 1]
-------findPostion-------
加之前q的巨细:6
加之后q的巨细:6
到前马[0, 0]时的q队列:
新增了:0个元素
===box===
[3, 1, 0, 6]
[7, 2, 1, 2]
[-1, 5, 4, 6]
[6, 3, 1, 3]
[2, 2]
[2, 1]
[2, 3]
[3, 0]
[0, 3]
[1, 0]
k:2
到当前马[2, 2]的访问列表:
[1, 1, 0, 0]
[0, 1, 1, 1]
[1, 0, 1, 0]
[0, 1, 1, 1]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:5
到前马[2, 2]时的q队列:
新增了:0个元素
===box===
[3, 1, 0, 6]
[7, 2, 1, 2]
[-1, 5, 4, 6]
[6, 3, 1, 3]
[2, 1]
[2, 3]
[3, 0]
[0, 3]
[1, 0]
k:2
到当前马[2, 1]的访问列表:
[1, 1, 0, 0]
[0, 1, 1, 1]
[1, 1, 1, 0]
[0, 1, 1, 1]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:5
到前马[2, 1]时的q队列:
新增了:1个元素
===box===
[3, 1, 8, 6]
[7, 2, 1, 2]
[-1, 5, 4, 6]
[6, 3, 1, 3]
[2, 3]
[3, 0]
[0, 3]
[1, 0]
[0, 2]
k:2
到当前马[2, 3]的访问列表:
[1, 1, 0, 0]
[0, 1, 1, 1]
[1, 1, 1, 1]
[0, 1, 1, 1]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:4
到前马[2, 3]时的q队列:
新增了:0个元素
===box===
[3, 1, 8, 6]
[7, 2, 1, 2]
[-1, 5, 4, 6]
[6, 3, 1, 3]
[3, 0]
[0, 3]
[1, 0]
[0, 2]
k:2
到当前马[3, 0]的访问列表:
[1, 1, 0, 0]
[0, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:3
到前马[3, 0]时的q队列:
新增了:0个元素
===box===
[3, 1, 8, 6]
[7, 2, 1, 2]
[-1, 5, 4, 6]
[6, 3, 1, 3]
[0, 3]
[1, 0]
[0, 2]
k:2
到当前马[0, 3]的访问列表:
[1, 1, 0, 1]
[0, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:2
到前马[0, 3]时的q队列:
新增了:0个元素
===box===
[3, 1, 8, 6]
[7, 2, 1, 2]
[-1, 5, 4, 6]
[6, 3, 1, 3]
[1, 0]
[0, 2]
k:2
到当前马[1, 0]的访问列表:
[1, 1, 0, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
-------findPostion-------
加之前q的巨细:1
加之后q的巨细:1
到前马[1, 0]时的q队列:
新增了:0个元素
===box===
[3, 1, 8, 6]
[7, 2, 1, 2]
[-1, 5, 4, 6]
[6, 3, 1, 3]
[0, 2]
k:2
到当前马[0, 2]的访问列表:
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[2, 1, 4, 3]
[4, 1, 1, 1]
[-1, 3, 2, 3]
[3, 2, 1, 2]
--===board-k===--
[3, 1, 8, 6]
[7, 2, 1, 2]
[-1, 5, 4, 6]
[6, 3, 1, 3]
8---------searchEachHorseFinished---------

11---------searchEachHorse---------
当前马为:坐标:[2,3],品级:2,当前层级:0当前步数:0
k:2
到当前马[2, 3]的访问列表:
[0, 0, 0, 0]
[0, 0, 0, 0]
[0, 0, 0, 1]
[0, 0, 0, 0]
-------findPostion-------
加之前q的巨细:0
加之后q的巨细:3
到前马[2, 3]时的q队列:
新增了:3个元素
===box===
[0, 0, 1, 0]
[0, 1, 0, 0]
[0, 0, 0, -1]
[0, 1, 0, 0]
[3, 1]
[1, 1]
[0, 2]
k:2
到当前马[3, 1]的访问列表:
[0, 0, 0, 0]
[0, 0, 0, 0]
[0, 0, 0, 1]
[0, 1, 0, 0]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:4
到前马[3, 1]时的q队列:
新增了:2个元素
===box===
[0, 0, 1, 0]
[2, 1, 2, 0]
[0, 0, 0, -1]
[0, 1, 0, 0]
[1, 1]
[0, 2]
[1, 2]
[1, 0]
k:2
到当前马[1, 1]的访问列表:
[0, 0, 0, 0]
[0, 1, 0, 0]
[0, 0, 0, 1]
[0, 1, 0, 0]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:6
到前马[1, 1]时的q队列:
新增了:3个元素
===box===
[0, 0, 1, 3]
[2, 1, 2, 0]
[0, 0, 0, -1]
[3, 1, 3, 0]
[0, 2]
[1, 2]
[1, 0]
[3, 2]
[3, 0]
[0, 3]
k:2
到当前马[0, 2]的访问列表:
[0, 0, 1, 0]
[0, 1, 0, 0]
[0, 0, 0, 1]
[0, 1, 0, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:6
到前马[0, 2]时的q队列:
新增了:1个元素
===box===
[0, 0, 1, 3]
[2, 1, 2, 0]
[0, 4, 0, -1]
[3, 1, 3, 0]
[1, 2]
[1, 0]
[3, 2]
[3, 0]
[0, 3]
[2, 1]
k:2
到当前马[1, 2]的访问列表:
[0, 0, 1, 0]
[0, 1, 1, 0]
[0, 0, 0, 1]
[0, 1, 0, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:8
到前马[1, 2]时的q队列:
新增了:3个元素
===box===
[5, 0, 1, 3]
[2, 1, 2, 0]
[5, 4, 0, -1]
[3, 1, 3, 5]
[1, 0]
[3, 2]
[3, 0]
[0, 3]
[2, 1]
[2, 0]
[3, 3]
[0, 0]
k:2
到当前马[1, 0]的访问列表:
[0, 0, 1, 0]
[1, 1, 1, 0]
[0, 0, 0, 1]
[0, 1, 0, 0]
-------findPostion-------
加之前q的巨细:7
加之后q的巨细:8
到前马[1, 0]时的q队列:
新增了:1个元素
===box===
[5, 0, 1, 3]
[2, 1, 2, 0]
[5, 4, 6, -1]
[3, 1, 3, 5]
[3, 2]
[3, 0]
[0, 3]
[2, 1]
[2, 0]
[3, 3]
[0, 0]
[2, 2]
k:2
到当前马[3, 2]的访问列表:
[0, 0, 1, 0]
[1, 1, 1, 0]
[0, 0, 0, 1]
[0, 1, 1, 0]
-------findPostion-------
加之前q的巨细:7
加之后q的巨细:8
到前马[3, 2]时的q队列:
新增了:1个元素
===box===
[5, 0, 1, 3]
[2, 1, 2, 7]
[5, 4, 6, -1]
[3, 1, 3, 5]
[3, 0]
[0, 3]
[2, 1]
[2, 0]
[3, 3]
[0, 0]
[2, 2]
[1, 3]
k:2
到当前马[3, 0]的访问列表:
[0, 0, 1, 0]
[1, 1, 1, 0]
[0, 0, 0, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:7
加之后q的巨细:7
到前马[3, 0]时的q队列:
新增了:0个元素
===box===
[5, 0, 1, 3]
[2, 1, 2, 7]
[5, 4, 6, -1]
[3, 1, 3, 5]
[0, 3]
[2, 1]
[2, 0]
[3, 3]
[0, 0]
[2, 2]
[1, 3]
k:2
到当前马[0, 3]的访问列表:
[0, 0, 1, 1]
[1, 1, 1, 0]
[0, 0, 0, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:6
加之后q的巨细:6
到前马[0, 3]时的q队列:
新增了:0个元素
===box===
[5, 0, 1, 3]
[2, 1, 2, 7]
[5, 4, 6, -1]
[3, 1, 3, 5]
[2, 1]
[2, 0]
[3, 3]
[0, 0]
[2, 2]
[1, 3]
k:2
到当前马[2, 1]的访问列表:
[0, 0, 1, 1]
[1, 1, 1, 0]
[0, 1, 0, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:5
到前马[2, 1]时的q队列:
新增了:0个元素
===box===
[5, 0, 1, 3]
[2, 1, 2, 7]
[5, 4, 6, -1]
[3, 1, 3, 5]
[2, 0]
[3, 3]
[0, 0]
[2, 2]
[1, 3]
k:2
到当前马[2, 0]的访问列表:
[0, 0, 1, 1]
[1, 1, 1, 0]
[1, 1, 0, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:5
到前马[2, 0]时的q队列:
新增了:1个元素
===box===
[5, 8, 1, 3]
[2, 1, 2, 7]
[5, 4, 6, -1]
[3, 1, 3, 5]
[3, 3]
[0, 0]
[2, 2]
[1, 3]
[0, 1]
k:2
到当前马[3, 3]的访问列表:
[0, 0, 1, 1]
[1, 1, 1, 0]
[1, 1, 0, 1]
[1, 1, 1, 1]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:4
到前马[3, 3]时的q队列:
新增了:0个元素
===box===
[5, 8, 1, 3]
[2, 1, 2, 7]
[5, 4, 6, -1]
[3, 1, 3, 5]
[0, 0]
[2, 2]
[1, 3]
[0, 1]
k:2
到当前马[0, 0]的访问列表:
[1, 0, 1, 1]
[1, 1, 1, 0]
[1, 1, 0, 1]
[1, 1, 1, 1]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:3
到前马[0, 0]时的q队列:
新增了:0个元素
===box===
[5, 8, 1, 3]
[2, 1, 2, 7]
[5, 4, 6, -1]
[3, 1, 3, 5]
[2, 2]
[1, 3]
[0, 1]
k:2
到当前马[2, 2]的访问列表:
[1, 0, 1, 1]
[1, 1, 1, 0]
[1, 1, 1, 1]
[1, 1, 1, 1]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:2
到前马[2, 2]时的q队列:
新增了:0个元素
===box===
[5, 8, 1, 3]
[2, 1, 2, 7]
[5, 4, 6, -1]
[3, 1, 3, 5]
[1, 3]
[0, 1]
k:2
到当前马[1, 3]的访问列表:
[1, 0, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
-------findPostion-------
加之前q的巨细:1
加之后q的巨细:1
到前马[1, 3]时的q队列:
新增了:0个元素
===box===
[5, 8, 1, 3]
[2, 1, 2, 7]
[5, 4, 6, -1]
[3, 1, 3, 5]
[0, 1]
k:2
到当前马[0, 1]的访问列表:
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[3, 4, 1, 2]
[1, 1, 1, 4]
[3, 2, 3, -1]
[2, 1, 2, 3]
--===board-k===--
[5, 8, 1, 3]
[2, 1, 2, 7]
[5, 4, 6, -1]
[3, 1, 3, 5]
11---------searchEachHorseFinished---------

12---------searchEachHorse---------
当前马为:坐标:[3,0],品级:1,当前层级:0当前步数:0
k:1
到当前马[3, 0]的访问列表:
[0, 0, 0, 0]
[0, 0, 0, 0]
[0, 0, 0, 0]
[1, 0, 0, 0]
-------findPostion-------
加之前q的巨细:0
加之后q的巨细:2
到前马[3, 0]时的q队列:
新增了:2个元素
===box===
[0, 0, 0, 0]
[0, 1, 0, 0]
[0, 0, 1, 0]
[-1, 0, 0, 0]
[2, 2]
[1, 1]
k:1
到当前马[2, 2]的访问列表:
[0, 0, 0, 0]
[0, 0, 0, 0]
[0, 0, 1, 0]
[1, 0, 0, 0]
-------findPostion-------
加之前q的巨细:1
加之后q的巨细:4
到前马[2, 2]时的q队列:
新增了:3个元素
===box===
[0, 2, 0, 2]
[2, 1, 0, 0]
[0, 0, 1, 0]
[-1, 0, 0, 0]
[1, 1]
[1, 0]
[0, 3]
[0, 1]
k:1
到当前马[1, 1]的访问列表:
[0, 0, 0, 0]
[0, 1, 0, 0]
[0, 0, 1, 0]
[1, 0, 0, 0]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:5
到前马[1, 1]时的q队列:
新增了:2个元素
===box===
[0, 2, 0, 2]
[2, 1, 0, 0]
[0, 0, 1, 3]
[-1, 0, 3, 0]
[1, 0]
[0, 3]
[0, 1]
[2, 3]
[3, 2]
k:1
到当前马[1, 0]的访问列表:
[0, 0, 0, 0]
[1, 1, 0, 0]
[0, 0, 1, 0]
[1, 0, 0, 0]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:6
到前马[1, 0]时的q队列:
新增了:2个元素
===box===
[0, 2, 4, 2]
[2, 1, 0, 0]
[0, 0, 1, 3]
[-1, 4, 3, 0]
[0, 3]
[0, 1]
[2, 3]
[3, 2]
[3, 1]
[0, 2]
k:1
到当前马[0, 3]的访问列表:
[0, 0, 0, 1]
[1, 1, 0, 0]
[0, 0, 1, 0]
[1, 0, 0, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:5
到前马[0, 3]时的q队列:
新增了:0个元素
===box===
[0, 2, 4, 2]
[2, 1, 0, 0]
[0, 0, 1, 3]
[-1, 4, 3, 0]
[0, 1]
[2, 3]
[3, 2]
[3, 1]
[0, 2]
k:1
到当前马[0, 1]的访问列表:
[0, 1, 0, 1]
[1, 1, 0, 0]
[0, 0, 1, 0]
[1, 0, 0, 0]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:6
到前马[0, 1]时的q队列:
新增了:2个元素
===box===
[0, 2, 4, 2]
[2, 1, 0, 5]
[5, 0, 1, 3]
[-1, 4, 3, 0]
[2, 3]
[3, 2]
[3, 1]
[0, 2]
[1, 3]
[2, 0]
k:1
到当前马[2, 3]的访问列表:
[0, 1, 0, 1]
[1, 1, 0, 0]
[0, 0, 1, 1]
[1, 0, 0, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:5
到前马[2, 3]时的q队列:
新增了:0个元素
===box===
[0, 2, 4, 2]
[2, 1, 0, 5]
[5, 0, 1, 3]
[-1, 4, 3, 0]
[3, 2]
[3, 1]
[0, 2]
[1, 3]
[2, 0]
k:1
到当前马[3, 2]的访问列表:
[0, 1, 0, 1]
[1, 1, 0, 0]
[0, 0, 1, 1]
[1, 0, 1, 0]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:4
到前马[3, 2]时的q队列:
新增了:0个元素
===box===
[0, 2, 4, 2]
[2, 1, 0, 5]
[5, 0, 1, 3]
[-1, 4, 3, 0]
[3, 1]
[0, 2]
[1, 3]
[2, 0]
k:1
到当前马[3, 1]的访问列表:
[0, 1, 0, 1]
[1, 1, 0, 0]
[0, 0, 1, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:4
到前马[3, 1]时的q队列:
新增了:1个元素
===box===
[0, 2, 4, 2]
[2, 1, 6, 5]
[5, 0, 1, 3]
[-1, 4, 3, 0]
[0, 2]
[1, 3]
[2, 0]
[1, 2]
k:1
到当前马[0, 2]的访问列表:
[0, 1, 1, 1]
[1, 1, 0, 0]
[0, 0, 1, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:4
到前马[0, 2]时的q队列:
新增了:1个元素
===box===
[0, 2, 4, 2]
[2, 1, 6, 5]
[5, 7, 1, 3]
[-1, 4, 3, 0]
[1, 3]
[2, 0]
[1, 2]
[2, 1]
k:1
到当前马[1, 3]的访问列表:
[0, 1, 1, 1]
[1, 1, 0, 1]
[0, 0, 1, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:3
到前马[1, 3]时的q队列:
新增了:0个元素
===box===
[0, 2, 4, 2]
[2, 1, 6, 5]
[5, 7, 1, 3]
[-1, 4, 3, 0]
[2, 0]
[1, 2]
[2, 1]
k:1
到当前马[2, 0]的访问列表:
[0, 1, 1, 1]
[1, 1, 0, 1]
[1, 0, 1, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:2
到前马[2, 0]时的q队列:
新增了:0个元素
===box===
[0, 2, 4, 2]
[2, 1, 6, 5]
[5, 7, 1, 3]
[-1, 4, 3, 0]
[1, 2]
[2, 1]
k:1
到当前马[1, 2]的访问列表:
[0, 1, 1, 1]
[1, 1, 1, 1]
[1, 0, 1, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:1
加之后q的巨细:3
到前马[1, 2]时的q队列:
新增了:2个元素
===box===
[8, 2, 4, 2]
[2, 1, 6, 5]
[5, 7, 1, 3]
[-1, 4, 3, 8]
[2, 1]
[3, 3]
[0, 0]
k:1
到当前马[2, 1]的访问列表:
[0, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 0]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:2
到前马[2, 1]时的q队列:
新增了:0个元素
===box===
[8, 2, 4, 2]
[2, 1, 6, 5]
[5, 7, 1, 3]
[-1, 4, 3, 8]
[3, 3]
[0, 0]
k:1
到当前马[3, 3]的访问列表:
[0, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
-------findPostion-------
加之前q的巨细:1
加之后q的巨细:1
到前马[3, 3]时的q队列:
新增了:0个元素
===box===
[8, 2, 4, 2]
[2, 1, 6, 5]
[5, 7, 1, 3]
[-1, 4, 3, 8]
[0, 0]
k:1
到当前马[0, 0]的访问列表:
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[8, 2, 4, 2]
[2, 1, 6, 5]
[5, 7, 1, 3]
[-1, 4, 3, 8]
--===board-k===--
[8, 2, 4, 2]
[2, 1, 6, 5]
[5, 7, 1, 3]
[-1, 4, 3, 8]
12---------searchEachHorseFinished---------

14---------searchEachHorse---------
当前马为:坐标:[3,2],品级:3,当前层级:0当前步数:0
k:3
到当前马[3, 2]的访问列表:
[0, 0, 0, 0]
[0, 0, 0, 0]
[0, 0, 0, 0]
[0, 0, 1, 0]
-------findPostion-------
加之前q的巨细:0
加之后q的巨细:3
到前马[3, 2]时的q队列:
新增了:3个元素
===box===
[0, 0, 0, 0]
[0, 1, 0, 1]
[1, 0, 0, 0]
[0, 0, -1, 0]
[2, 0]
[1, 3]
[1, 1]
k:3
到当前马[2, 0]的访问列表:
[0, 0, 0, 0]
[0, 0, 0, 0]
[1, 0, 0, 0]
[0, 0, 1, 0]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:4
到前马[2, 0]时的q队列:
新增了:2个元素
===box===
[0, 2, 0, 0]
[0, 1, 2, 1]
[1, 0, 0, 0]
[0, 0, -1, 0]
[1, 3]
[1, 1]
[1, 2]
[0, 1]
k:3
到当前马[1, 3]的访问列表:
[0, 0, 0, 0]
[0, 0, 0, 1]
[1, 0, 0, 0]
[0, 0, 1, 0]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:4
到前马[1, 3]时的q队列:
新增了:1个元素
===box===
[0, 2, 0, 0]
[0, 1, 2, 1]
[1, 3, 0, 0]
[0, 0, -1, 0]
[1, 1]
[1, 2]
[0, 1]
[2, 1]
k:3
到当前马[1, 1]的访问列表:
[0, 0, 0, 0]
[0, 1, 0, 1]
[1, 0, 0, 0]
[0, 0, 1, 0]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:6
到前马[1, 1]时的q队列:
新增了:3个元素
===box===
[0, 2, 0, 4]
[0, 1, 2, 1]
[1, 3, 0, 4]
[4, 0, -1, 0]
[1, 2]
[0, 1]
[2, 1]
[2, 3]
[3, 0]
[0, 3]
k:3
到当前马[1, 2]的访问列表:
[0, 0, 0, 0]
[0, 1, 1, 1]
[1, 0, 0, 0]
[0, 0, 1, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:8
到前马[1, 2]时的q队列:
新增了:3个元素
===box===
[5, 2, 0, 4]
[0, 1, 2, 1]
[1, 3, 0, 4]
[4, 5, -1, 5]
[0, 1]
[2, 1]
[2, 3]
[3, 0]
[0, 3]
[3, 3]
[3, 1]
[0, 0]
k:3
到当前马[0, 1]的访问列表:
[0, 1, 0, 0]
[0, 1, 1, 1]
[1, 0, 0, 0]
[0, 0, 1, 0]
-------findPostion-------
加之前q的巨细:7
加之后q的巨细:8
到前马[0, 1]时的q队列:
新增了:1个元素
===box===
[5, 2, 0, 4]
[0, 1, 2, 1]
[1, 3, 6, 4]
[4, 5, -1, 5]
[2, 1]
[2, 3]
[3, 0]
[0, 3]
[3, 3]
[3, 1]
[0, 0]
[2, 2]
k:3
到当前马[2, 1]的访问列表:
[0, 1, 0, 0]
[0, 1, 1, 1]
[1, 1, 0, 0]
[0, 0, 1, 0]
-------findPostion-------
加之前q的巨细:7
加之后q的巨细:8
到前马[2, 1]时的q队列:
新增了:1个元素
===box===
[5, 2, 7, 4]
[0, 1, 2, 1]
[1, 3, 6, 4]
[4, 5, -1, 5]
[2, 3]
[3, 0]
[0, 3]
[3, 3]
[3, 1]
[0, 0]
[2, 2]
[0, 2]
k:3
到当前马[2, 3]的访问列表:
[0, 1, 0, 0]
[0, 1, 1, 1]
[1, 1, 0, 1]
[0, 0, 1, 0]
-------findPostion-------
加之前q的巨细:7
加之后q的巨细:7
到前马[2, 3]时的q队列:
新增了:0个元素
===box===
[5, 2, 7, 4]
[0, 1, 2, 1]
[1, 3, 6, 4]
[4, 5, -1, 5]
[3, 0]
[0, 3]
[3, 3]
[3, 1]
[0, 0]
[2, 2]
[0, 2]
k:3
到当前马[3, 0]的访问列表:
[0, 1, 0, 0]
[0, 1, 1, 1]
[1, 1, 0, 1]
[1, 0, 1, 0]
-------findPostion-------
加之前q的巨细:6
加之后q的巨细:6
到前马[3, 0]时的q队列:
新增了:0个元素
===box===
[5, 2, 7, 4]
[0, 1, 2, 1]
[1, 3, 6, 4]
[4, 5, -1, 5]
[0, 3]
[3, 3]
[3, 1]
[0, 0]
[2, 2]
[0, 2]
k:3
到当前马[0, 3]的访问列表:
[0, 1, 0, 1]
[0, 1, 1, 1]
[1, 1, 0, 1]
[1, 0, 1, 0]
-------findPostion-------
加之前q的巨细:5
加之后q的巨细:5
到前马[0, 3]时的q队列:
新增了:0个元素
===box===
[5, 2, 7, 4]
[0, 1, 2, 1]
[1, 3, 6, 4]
[4, 5, -1, 5]
[3, 3]
[3, 1]
[0, 0]
[2, 2]
[0, 2]
k:3
到当前马[3, 3]的访问列表:
[0, 1, 0, 1]
[0, 1, 1, 1]
[1, 1, 0, 1]
[1, 0, 1, 1]
-------findPostion-------
加之前q的巨细:4
加之后q的巨细:4
到前马[3, 3]时的q队列:
新增了:0个元素
===box===
[5, 2, 7, 4]
[0, 1, 2, 1]
[1, 3, 6, 4]
[4, 5, -1, 5]
[3, 1]
[0, 0]
[2, 2]
[0, 2]
k:3
到当前马[3, 1]的访问列表:
[0, 1, 0, 1]
[0, 1, 1, 1]
[1, 1, 0, 1]
[1, 1, 1, 1]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:4
到前马[3, 1]时的q队列:
新增了:1个元素
===box===
[5, 2, 7, 4]
[8, 1, 2, 1]
[1, 3, 6, 4]
[4, 5, -1, 5]
[0, 0]
[2, 2]
[0, 2]
[1, 0]
k:3
到当前马[0, 0]的访问列表:
[1, 1, 0, 1]
[0, 1, 1, 1]
[1, 1, 0, 1]
[1, 1, 1, 1]
-------findPostion-------
加之前q的巨细:3
加之后q的巨细:3
到前马[0, 0]时的q队列:
新增了:0个元素
===box===
[5, 2, 7, 4]
[8, 1, 2, 1]
[1, 3, 6, 4]
[4, 5, -1, 5]
[2, 2]
[0, 2]
[1, 0]
k:3
到当前马[2, 2]的访问列表:
[1, 1, 0, 1]
[0, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
-------findPostion-------
加之前q的巨细:2
加之后q的巨细:2
到前马[2, 2]时的q队列:
新增了:0个元素
===box===
[5, 2, 7, 4]
[8, 1, 2, 1]
[1, 3, 6, 4]
[4, 5, -1, 5]
[0, 2]
[1, 0]
k:3
到当前马[0, 2]的访问列表:
[1, 1, 1, 1]
[0, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
-------findPostion-------
加之前q的巨细:1
加之后q的巨细:1
到前马[0, 2]时的q队列:
新增了:0个元素
===box===
[5, 2, 7, 4]
[8, 1, 2, 1]
[1, 3, 6, 4]
[4, 5, -1, 5]
[1, 0]
k:3
到当前马[1, 0]的访问列表:
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[2, 1, 3, 2]
[3, 1, 1, 1]
[1, 1, 2, 2]
[2, 2, -1, 2]
--===board-k===--
[5, 2, 7, 4]
[8, 1, 2, 1]
[1, 3, 6, 4]
[4, 5, -1, 5]
14---------searchEachHorseFinished---------
[-1, 4, 3, 8]
[5, 6, 1, 3]
[2, 1, 7, 5]
[8, 2, 4, 2]
[1, -1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, -1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[2, 1, 1, -1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 2]
[3, 3, 1, 1]
[2, -1, 2, 1]
[1, 2, 2, 1]
[1, 1, 1, 3]
[1, 1, 1, 2]
[1, 1, 1, -1]
[1, 1, 1, 1]
[2, 2, 1, 1]
[2, 1, 4, 3]
[4, 1, 1, 1]
[-1, 3, 2, 3]
[3, 2, 1, 2]
[3, 4, 1, 2]
[1, 1, 1, 4]
[3, 2, 3, -1]
[2, 1, 2, 3]
[8, 2, 4, 2]
[2, 1, 6, 5]
[5, 7, 1, 3]
[-1, 4, 3, 8]
[2, 1, 3, 2]
[3, 1, 1, 1]
[1, 1, 2, 2]
[2, 2, -1, 2]
---------checkBoard---------
[22, 17, 18, 21]
[21, 13, 16, 17]
[15, 20, 21, 17]
[20, 17, 14, 25]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
[1, 1, 1, 1]
13
能将全部马跳到同一位置,且最少需要的总步数为:13
 
3.带数据分析完备代码

  1. import javax.security.auth.kerberos.KerberosCredMessage;import java.util.*;public class test34 {    public static  void main(String[] args) {
  2.         /*
  3.         Scanner sc = new Scanner(System.in);
  4.         System.out.println("请输入棋盘行数m:");
  5.         int m = sc.nextInt();
  6.         System.out.println("请输入棋盘列数n:");
  7.         int n = sc.nextInt();
  8.         System.out.println("请输入马在棋盘上的分布:");
  9.         int[][] horses = new int[m][n];
  10.         for (int i = 0; i < m; i++) {
  11.             for (int j = 0; j < n; j++) {
  12.                 horses[i][j] = sc.nextInt();
  13.             }
  14.         }
  15.         sc.close();
  16.         System.out.println(Arrays.deepToString(horses));
  17.         */
  18.         int m = 4;
  19.         int n = 4;
  20.         int[][] horse = {{1,9,9,7},{0,3,0,6},{2,0,0,2},{1,0,3,0}};
  21.         ArrayList<Horse> horses = turnToHorse(horse);
  22.         int minStep = searhEachHorse(horses,m,n);
  23.         if (minStep==-1){
  24.             System.out.println("不能将所有马跳到同一位置");
  25.         }else {
  26.             System.out.println("能将所有马跳到同一位置,且最少需要的总步数为:"+minStep);
  27.         }
  28.     }    private static int searhEachHorse(ArrayList<Horse> horses, int m, int n) {
  29.         //每一匹马的位置和步数board组成所有马的boards
  30.         ArrayList<int[][]> boards = new ArrayList<>();
  31.         for (int i = 0; i < horses.size(); i++) {//每一匹马
  32.             //先看一匹
  33.             //for (int i = 1; i < 2; i++) {
  34.                 Horse horse = horses.get(i);
  35.             if (horse.k!=0){
  36.                 //每一匹马都给个board,存的是每个位置所需要的步数step(step根据k算出每个位置的最小步数!)
  37.                 int[][] board = new int[m][n];
  38.                 int[][] boardk = new int[m][n];
  39.                 int k =horse.k;//跳步级别
  40.                 System.out.println("\n"+i+"---------searchEachHorse---------");
  41.                 System.out.print("当前马为:"+horse.toString());
  42.                 int[] horseZk = horse.getPostion();
  43.                 int[][] visit = new int[m][n];
  44.                 int[][] visited;
  45.                 Queue<int[]> q = new LinkedList<>();//要随调用传值
  46.                 q.add(horseZk);
  47.                 int[][] box = new int[m][n];//传值
  48.                 int level = 0;
  49.                 board = findPostion(horse,m,n,visit,q,box,level);//找完位置返回含有step信息的board
  50.                 boardk = boardCal(board,k);
  51.                 System.out.println("--===board-k===--");
  52.                 for (int[] row : board) {
  53.                     System.out.println(Arrays.toString(row));
  54.                 }
  55.                 boards.add(boardk);
  56.                 System.out.println(i+"---------searchEachHorseFinished---------\n");
  57.             }
  58.         }
  59.         //获得了所有马在棋盘上的位置和步数信息
  60.         for (int[][] board : boards) {
  61.             for (int[] row : board) {
  62.                 System.out.print(Arrays.toString(row)+"\n");
  63.             }
  64.             System.out.println();
  65.         }
  66.         int totalStep = CheckBoards(m,n,boards);
  67.         return totalStep;
  68.     }    private static int CheckBoards(int m,int n,ArrayList<int[][]> boards) {
  69.         System.out.println("---------checkBoard---------");
  70.         int totalSteps = 0 ;
  71.         int[][] exist = new int[m][n];
  72.         boolean allCanArr = true;
  73.         for (int i = 0; i < m; i++) {
  74.             Arrays.fill(exist[i], 1); // 填充每一行
  75.         }//默认都存在
  76.         int[][] AddStep = new int[m][n];
  77.         for (int i = 0; i <m; i++) {
  78.             for (int j = 0; j < n; j++) {
  79.                 int addSteps = 0;
  80.                 for (int k = 0; k < boards.size(); k++) {
  81.                     //System.out.println(boards.get(k)[i][j]);
  82.                     if (boards.get(k)[i][j] == 0) {//检验是否存在有马到不了的位置
  83.                         exist[i][j] = 0;
  84.                     }
  85.                     addSteps += boards.get(k)[i][j];
  86.                 }
  87.                 AddStep[i][j] = addSteps;
  88.             }
  89.         }
  90.         for (int[] row : AddStep) {
  91.             for (int val : row) {
  92.                 if (val == 1) {
  93.                     allCanArr = false;
  94.                 }
  95.             }
  96.             System.out.println(Arrays.toString(row));
  97.         }
  98.         for (int[] existBoard : exist) {
  99.             System.out.println(Arrays.toString(existBoard));
  100.         }
  101.         int minStep = Integer.MAX_VALUE;
  102.         for (int i = 0; i < m; i++) {
  103.             for (int j = 0; j <n; j++) {
  104.                 minStep = Math.min(minStep,AddStep[i][j]);
  105.             }
  106.         }
  107.         totalSteps = minStep;
  108.         System.out.println(totalSteps);
  109.         if (allCanArr) {
  110.             return totalSteps;
  111.         }else{
  112.             return -1;
  113.         }
  114.     }    private static int[][] boardCal(int[][] board, int k) {
  115.         int[][] boardk = new int[board.length][board[0].length];
  116.         for (int i = 0; i < board.length; i++) {
  117.             for (int j = 0; j < board[0].length; j++) {
  118.                 boardk[i][j] = board[i][j];
  119.                 if (boardk[i][j] <= k&&boardk[i][j] !=-1) {//=============================2
  120.                     boardk[i][j]= 1;
  121.                 } else if (boardk[i][j] > k) {
  122.                     /*小于:eg:k=2,step=5=2+2+1,step=7=2+2+2+1*/
  123.                     int r = board[i][j]%k;
  124.                     if (r==0){
  125.                         boardk[i][j] =board[i][j]/k;
  126.                     }else {
  127.                         boardk[i][j] = board[i][j]/k+ 1;
  128.                     }
  129.                 }
  130.             }
  131.         }
  132.         for (int[] row : boardk) {
  133.             System.out.println(Arrays.toString(row));
  134.         }
  135.         return boardk;
  136.     }
  137.     private static ArrayList<Horse> turnToHorse(int[][] horse) {
  138.         ArrayList<Horse> horses = new ArrayList<>();
  139.         for (int i = 0; i < horse.length; i++) {
  140.             for (int j = 0; j < horse[i].length; j++) {
  141.                 int[] postion =new int[2];
  142.                 int k = 0;
  143.                 postion[0] = i;
  144.                 postion[1] = j;
  145.                 k = horse[i][j];
  146.                 horses.add(new Horse(postion,k,0,0));
  147.             }
  148.         }
  149.         return horses;
  150.     }    static int[][] DIRECTION={{1,2},{1,-2},
  151.             {2,1},{2,-1},
  152.             {-1,2},{-1,-2},
  153.             {-2,1},{-2,-1}};    static ArrayList<int[]> postions = new ArrayList<>();//协助观察
  154.     private static int[][] findPostion(Horse horse,int m,int n,int[][] visit,Queue<int[]> q,int[][]box,int level ) {
  155.         //变化量:step、level注意传值
  156.         int k = horse.k;
  157.         System.out.println("k:"+k);
  158.         box[horse.postion[0]][horse.postion[1]] = -1;//=============================1
  159.         while (!q.isEmpty()) {
  160.             //队列中遍历
  161.             int[] temp = q.poll();
  162.             visit[temp[0]][temp[1]] = 1;
  163.             ///*
  164.             System.out.println("到当前马"+Arrays.toString(temp)+"的访问列表:");
  165.             for (int[] row : visit) {
  166.                 System.out.println(Arrays.toString(row));
  167.             }
  168.             if (Arrays.stream(visit)
  169.                     .flatMapToInt(Arrays::stream) // 将二维数组扁平化为一维流
  170.                     .allMatch(value -> value == 1)){
  171.                 return visit;
  172.             }
  173.            // */
  174.             System.out.println("-------findPostion-------");
  175.             int size = q.size();
  176.             System.out.println("加之前q的大小:"+size);
  177.             for (int[] direction : DIRECTION) {
  178.                 int x = temp[0]+ direction[0];
  179.                 int y = temp[1] + direction[1];
  180.                 //System.out.println("("+x+","+y+")");
  181.                 int[] Z = {x,y};
  182.                 boolean contains = false;
  183.                 for (int[] currentArray : q) {
  184.                     if (Arrays.equals(currentArray, Z)) {
  185.                         contains = true; // 找到相同的数组
  186.                     }
  187.                 }
  188.                 if (x>=0&&x<n&&y>=0&&y<m&&visit[x][y]==0&&!contains) {//只加入没去过的点
  189.                     postions.add(Z);//协助观察
  190.                     q.add(Z);
  191.                 }
  192.             }
  193.             int size1 = q.size();
  194.             System.out.println("加之后q的大小:"+size1);
  195.             System.out.println("到前马"+Arrays.toString(temp)+"时的q队列:");
  196.             int newadd = size1 - size;
  197.             System.out.println("新增了:"+newadd+"个元素");
  198.             /*写到这里了,层级的自增!!!!!!!!!*/
  199.             if(newadd>0){
  200.                 level++;
  201.             }
  202.             List<int[]> list = new ArrayList<>(q);
  203.             for (int i = size1-1; i >=size; i--) {
  204.                 box[list.get(i)[0]][list.get(i)[1]] = level;
  205.             }
  206.             System.out.println("===box===");
  207.             for (int[] row : box) {
  208.                 System.out.println(Arrays.toString(row));
  209.             }
  210.             for (int[] element : q) {
  211.                 System.out.println(Arrays.toString(element));
  212.             }
  213.             findPostion(horse,m,n,visit,q,box,level);
  214.         }
  215.         //return visit;
  216.         return box;
  217.     }    public static class Horse{
  218.         int[] postion;
  219.         int k;
  220.         int level;
  221.         int step;
  222.         public Horse(int[] postion, int k, int level,int step) {
  223.             this.postion = postion;
  224.             this.k = k;
  225.             this.level = level;
  226.             this.step = step;
  227.         }
  228.         public String toString(){
  229.             return "坐标:["+postion[0]+","+postion[1]+"],等级:"+k+",当前层级:"+level+"当前步数:"+step+"\n";
  230.         }
  231.         public int getK(){
  232.             return k;
  233.         }
  234.         public int getLevel(){
  235.             return level;
  236.         }
  237.         public int[] getPostion(){
  238.             return postion;
  239.         }
  240.     }}
复制代码


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

罪恶克星

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表