This Java Program is to Implement Knight’s Tour Problem.A knight’s tour is a sequence of moves of a knight on a chessboard such that the knight visits every square exactly once. If the knight ends on a square that is one knight’s move from the beginning square (so that it could tour the board again immediately, following the same path), the tour is closed, otherwise it is open. The exact number of open tours on an 8×8 chessboard is still unknown.
Here is the source code of the Java Program to Implement Knight’s Tour Problem. The Java program is successfully compiled and run on a Linux system. The program output is also shown below.
package com.vipin.algorithms; public class KnightTour { private static final int N = 8; private int soln[][]; public KnightTour() { soln = new int[N][N]; } private boolean isSafe(int x, int y) { if (x >= 0 && x < N && y >= 0 && y < N && soln[x][y] == -1) return true; return false; } private void printSolution() { for (int x = 0; x < N; x++) { for (int y = 0; y < N; y++) { System.out.print(" " + soln[x][y]); } System.out.println(); } } private boolean solveKTUtil(int x, int y, int movei, int xMove[],int yMove[]) { int k, next_x, next_y; if (movei == N * N) return true; for (k = 0; k < N; k++) { next_x = x + xMove[k]; next_y = y + yMove[k]; if (isSafe(next_x, next_y)) { soln[next_x][next_y] = movei; if (solveKTUtil(next_x, next_y, movei + 1, xMove, yMove)) return true; else soln[next_x][next_y] = -1; } } return false; } public boolean solveKnightTour() { for (int x = 0; x < N; x++) { for (int y = 0; y < N; y++) { soln[x][y] = -1; } } int xMove[] = { 2, 1, -1, -2, -2, -1, 1, 2 }; int yMove[] = { 1, 2, 2, 1, -1, -2, -2, -1 }; soln[0][0] = 0; if (!solveKTUtil(0, 0, 1, xMove, yMove)) { System.out.println("the solution does not exist"); return false; } else { printSolution(); } return true; } public static void main(String... arg) { KnightTour knightTour = new KnightTour(); System.out.println("the solution is"); knightTour.solveKnightTour(); } }
$javac KnightTour.java $java KnightTour the solution is 0 59 38 33 30 17 8 63 37 34 31 60 9 62 29 16 58 1 36 39 32 27 18 7 35 48 41 26 61 10 15 28 42 57 2 49 40 23 6 19 47 50 45 54 25 20 11 14 56 43 52 3 22 13 24 5 51 46 55 44 53 4 21 12
Related posts:
Apache Commons Collections MapUtils
Java – Generate Random String
Shuffling Collections In Java
A Guide to @RepeatedTest in Junit 5
OAuth 2.0 Resource Server With Spring Security 5
Giới thiệu Design Patterns
Converting a Stack Trace to a String in Java
Spring Security and OpenID Connect
Encode/Decode to/from Base64
Java Program to Implement Interpolation Search Algorithm
SOAP Web service: Upload và Download file sử dụng MTOM trong JAX-WS
Java Program to Check the Connectivity of Graph Using DFS
Spring Data JPA @Modifying Annotation
Queue và PriorityQueue trong Java
Weak References in Java
Loại bỏ các phần tử trùng trong một ArrayList như thế nào?
Initialize a HashMap in Java
Merging Two Maps with Java 8
A Guide to Spring Boot Admin
Spring Cloud – Adding Angular
Java Program to Implement Min Hash
Model, ModelMap, and ModelAndView in Spring MVC
Java Program to Use Above Below Primitive to Test Whether Two Lines Intersect
Guide to Selenium with JUnit / TestNG
Java 8 Predicate Chain
Introduction to Spring Security Expressions
Java Program to Implement Direct Addressing Tables
Introduction to Spring Cloud CLI
Serve Static Resources with Spring
Java Program to Implement Adjacency Matrix
Java – Reader to InputStream
Spring Boot Integration Testing with Embedded MongoDB