资源简介
JAVA实现骑士巡游(马踏棋盘)
8X8格
输入起始X轴Y轴坐标
代码片段和文件信息
import java.applet.applet;
import java.awt.Graphics;
import java.awt.Color;
import javax.swing.JOptionPane;
import java.awt.Font;
//提供二元型数值
class Pair
{
private int x;
private int y;
// Pair()
// {
// }
Pair(int aint b)
{
x=a;
y=b;
}
public int getX()
{
return x;
}
public int getY()
{
return y;
}
}
//提供巡游结果
class GetKnightCruise
{
//存储8*8棋盘上各位置为第几步
private static int[][] arr=new int[8][8];
//用来存储骑士可以到达的8个位置的偏移量
private static Pair[] index=new Pair[8];
//设置index的初始值
int ab;
private static void setIndex()
{
index[0]=new Pair(-21);
index[1]=new Pair(-12);
index[2]=new Pair(12);
index[3]=new Pair(21);
index[4]=new Pair(2-1);
index[5]=new Pair(1-2);
index[6]=new Pair(-1-2);
index[7]=new Pair(-2-1);
}
//设置棋盘位置的处始值
private static void setArr()
{
for (int i=0;i<8;i++)
{
for (int j=0;j<8;j++)
{
arr[i][j]=0;
}
}
}
//计算位置(ij)的出口数
private static int getExitNum(int iint j)
{
int num=0;
for(int t=0;t<8;t++)
{
if(i+index[t].getX()>=0&&i+index[t].getX()<=7&&j+index[t].getY()>=0&&j+index[t].getY()<=7&&arr[i+index[t].getX()][j+index[t].getY()]==0)
{
num++;
}
}
return num;
}
//选择下一个所走的位置,beginIndex的作用是定位选择优先权的起始位置
private static Pair getNextPositioin(int iint jint beginIndex)
{
int[] temp=new int[8];
int min=8;
for(int t=0;t<8;t++)
{
if(i+index[t].getX()>=0&&i+index[t].getX()<=7&&j+index[t].getY()>=0&&j+index[t].getY()<=7&&arr[i+index[t].getX()][j+index[t].getY()]==0)
{
temp[t]=getExitNum(i+index[t].getX()j+index[t].getY());
if(temp[t]!=0&&temp[t] {
min=temp[t];
}
}
}
for(int t=0;t<8;t++)
{
int h=(t+beginIndex)%8;
if(temp[h]==min)
{
return new Pair(i+index[h].getX()j+index[h].getY());
}
}
return new Pair(-1-1);
}
//寻找下一个唯一的出口(主要给最后一步使用,因为getNextPositioin已经不适合了)
private static Pair getNextPositioinOfTheLastStep(int iint j)
{
for(int t=0;t<8;t++)
{
if(i+index[t].getX()>=0&&i+index[t].getX()<=7&&j+index[t].getY()>=0&&j+index[t].getY()<=7&&arr[i+index[t].getX()][j+index[t].getY()]==0)
{
return new Pair(i+index[t].getX()j+index[t].getY());
}
}
return new Pair(-1-1);
}
//从(ij)开始骑士巡游
static int[][] getKnightCruise(int iint j)
{
Pair tt;
setArr();
setIndex();
for(int q=0;q<8;q++)
{
int ii=ijj=j;
int p=0;
for(p=1;p<=64;p++)
{
arr[ii][jj]=p;
if(p==63)
{
tt=getNextPositioinOfTheLastStep(iijj);
ii=tt.getX();
jj=tt.getY();
continue;
}
tt=getNextPositioin(iijjp);
ii=tt.getX();
jj=tt.getY();
if(ii==-1||jj==-1)
{
break;
}
}
if(p==65)
{
// return;
return arr;
}
}
return arr;
}
//得到巡游数组
public static int[][] getResult()
{
// int i=0j=0;
int i=1j=1;
getKnightCruise(ij);
return
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 2134 2009-11-13 15:09 马踏棋盘问题\GetKnightCruise.class
文件 2068 2009-11-13 15:09 马踏棋盘问题\mataqipanqiujiewenti1.class
文件 4633 2007-06-30 10:55 马踏棋盘问题\mataqipanqiujiewenti1.java
文件 115 2007-05-16 22:38 马踏棋盘问题\mataqipanwenti.html
文件 383 2009-11-13 15:09 马踏棋盘问题\Pair.class
目录 0 2009-11-13 15:09 马踏棋盘问题
----------- --------- ---------- ----- ----
9333 6
相关资源
- Java语言程序设计叶乃文 程序代码
- 飞行棋回合中·代码.java
- 2015年传智播客java第33期全套完整.tx
- 轻量级JavaEE企业级应用实战.txt
- 基于java的协同过滤
- 毕向东javaSE基础视频35天.txt
- Java版数据结构与算法视频教程(44集
- java聊天java聊天java聊天java聊天java聊天
- MQTT相关java代码实现
- AutoItX4Java
- 使用java语言实现的QQ聊天软件
- 用java实现基于文件的图书管理系统
- Java实现分词正向最大匹配和逆向最大
- java 公式计算汇总,直接调用其方法即
- java sqlserver 酒店管理系统 源码
- 基于jspjava的毕业设计源码
- 毕业设计_java+sql2000员工管理系统
- java语言解决八数码问题完整版
- 带有界面的基于UDP通信的多人聊天代
- java程序设计之网络编程第二版课后习
- jsp+servlet+javabean实现简单购物车
- log4j-1.2.15-sources.jar
- java 坦克大战 ppt 和 源码
- java+oracle实现学生管理系
- JAVA画2叉树
- goldengate for java
- Java中国象棋单机版186025
- jsp 宠物管理系统
- java网络聊天室课程设计报告内
- java实现excel表格文件的复制
评论
共有 条评论