java实现马踏棋盘游戏
更新时间:2022年02月14日 11:38:32 作者:会钓猫的鱼
这篇文章主要为大家详细介绍了java实现马踏棋盘游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
用java实现马踏棋盘游戏算法,供大家参考,具体内容如下
在4399小游戏中有这样一个游戏
这是代码实现
package com.HorseChess; import java.awt.*; import java.util.ArrayList; import java.util.Comparator; import java.util.Scanner; public class HorseChess { private static int X; private static int Y; private static boolean visited[]; private static boolean finished; public static void main(String[] args) { Scanner sc = new Scanner(System.in); System.out.println("请输入行:"); X = sc.nextInt(); System.out.println("请输入列:"); Y = sc.nextInt(); System.out.println("请输入棋子所在行:"); int row = sc.nextInt(); System.out.println("请输入棋子所在列:"); int column = sc.nextInt(); int [][] chessboard = new int[X][Y]; visited = new boolean[X*Y]; traverchess(chessboard,row-1,column-1,1); for(int[] rows : chessboard){ for (int step : rows){ System.out.print(step + "\t"); } System.out.println(); } } public static void traverchess(int[][] chessboard,int row,int column,int step){ chessboard[row][column] = step; visited[row * X+column] = true; ArrayList<Point> ps = next(new Point(column,row)); sort(ps); while (!ps.isEmpty()){ Point p = ps.remove(0); if(!visited[p.y*X+p.x]){ traverchess(chessboard,p.y,p.x,step+1); } } if(step<X*Y&&!finished){ chessboard[row][column] = 0; visited[row * X + column] = false; } else { finished = true; } } //判断当前棋子下一个可以走的所有位置数组 public static ArrayList<Point> next(Point curpoint){ ArrayList<Point> ps = new ArrayList<Point>(); Point p1 = new Point(); if((p1.x = curpoint.x - 2)>=0&&(p1.y = curpoint.y - 1)>=0){ ps.add(new Point(p1)); } if((p1.x = curpoint.x - 1)>=0&&(p1.y = curpoint.y - 2)>=0){ ps.add(new Point(p1)); } if((p1.x = curpoint.x + 1)< X && (p1.y = curpoint.y - 2)>=0){ ps.add(new Point(p1)); } if((p1.x = curpoint.x + 2)< X && (p1.y = curpoint.y - 1)>=0){ ps.add(new Point(p1)); } if((p1.x = curpoint.x + 2)<X&&(p1.y = curpoint.y + 1)<Y){ ps.add(new Point(p1)); } if((p1.x = curpoint.x + 1)<X&&(p1.y = curpoint.y + 2)<Y){ ps.add(new Point(p1)); } if((p1.x = curpoint.x - 1)>=0&&(p1.y = curpoint.y + 2)<Y){ ps.add(new Point(p1)); } if((p1.x = curpoint.x - 2)>=0&&(p1.y = curpoint.y + 1)<Y){ ps.add(new Point(p1)); } return ps; } //使用贪心算法提高算法运行速度 public static void sort(ArrayList<Point> ps){ ps.sort(new Comparator<Point>() { @Override public int compare(Point o1, Point o2) { int count1 = next(o1).size(); int count2 = next(o2).size(); if(count1<count2){ return -1; }else if (count1 == count2){ return 0; } else { return 1; } } }); } }
然后照着步骤一步一步下就可以了
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
SpringBoot整合MyBatisPlus配置动态数据源的方法
这篇文章主要介绍了SpringBoot整合MyBatisPlus配置动态数据源的方法,本文给大家介绍的非常详细,具有一定的参考借鉴价值 ,需要的朋友可以参考下2019-05-05Java getRealPath("/")与getContextPath()区别详细分析
这篇文章主要介绍了Java getRealPath("/")与getContextPath()区别详细分析,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下2021-08-08
最新评论