资源简介
Java版中国象棋人机对战源代码(AI算法体现淋漓尽致)

代码片段和文件信息
package org.acerge.engine;
import java.io.Serializable;
import java.util.ArrayList;
public class ActiveBoard implements Serializable{
//Rank[x]File[x]Bottom[x] 比 x % 10x / 10x * 10运算快
public static final int[] RANK = {// File[19]=1Rank[19]=9;
0 1 2 3 4 5 6 7 8 9
0 1 2 3 4 5 6 7 8 9
0 1 2 3 4 5 6 7 8 9
0 1 2 3 4 5 6 7 8 9
0 1 2 3 4 5 6 7 8 9
0 1 2 3 4 5 6 7 8 9
0 1 2 3 4 5 6 7 8 9
0 1 2 3 4 5 6 7 8 9
0 1 2 3 4 5 6 7 8 9
};
public static final int FILE[] = {// File[12]=1Rank[12]=2;
0 0 0 0 0 0 0 0 0 0
1 1 1 1 1 1 1 1 1 1
2 2 2 2 2 2 2 2 2 2
3 3 3 3 3 3 3 3 3 3
4 4 4 4 4 4 4 4 4 4
5 5 5 5 5 5 5 5 5 5
6 6 6 6 6 6 6 6 6 6
7 7 7 7 7 7 7 7 7 7
8 8 8 8 8 8 8 8 8 8
};
public static final int[] BOTTOM = {
0 10 20 30 40 50 60 70 80
};
public static final int[] HORSE_LEG_TABLE = {//int
-10 0-10 0 0 0 0 0 0 -1 0
0 0 1 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 -1 0 0 0
1 0 0 0 0 0 0 10 0 10
//Move.Dst - Move.Src={-21-19-12-88121921}
//HorseLeg[Dst-Src+21]={-10-10-11-111010}:蹩马腿的增量
//Legal Move: return Squares[Move.Src + HorseLegTab[Move.Dst - Move.Src + 21]]==0
};
public static final int[] PIECE_TYPES = {
-1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1
0 1 1 2 2 3 3 4 4 5 5 6 6 6 6 6
7 8 8 9 9 10 10 11 11 12 12 13 13 13 13 13
};
public final static int MAX_MOVE_NUM = 256;
public final static int LOOP_HASH_MASK = 0x3ff;
public final static int MAX_CONSECUTIVE_MOVES = 200;
private int player; // 0 = Red(White) and 1 = Black
private int[] evalue;//int[2]Total Value of Red(0)/Black(1) Pieces
private int[] squares;//int[90]Piece Indexes of each square Squares[i] = 0:Unoccupied 16-31:Red 32-47 = Black
private int[] pieces;//int[48]Square Indexes of each piece -1 = Captured//被吃了
// Square[x]=y(y: index of PieceTypes in Square[x])
// Pieces[y]=x(y is the pieceType x represent pieceType Y in Square 5)
// x:index of location in board(0~89)
private int[] bitFiles;//[9]方便按行位纵线查询BitFiles[1]表示第1列(b纵线)上的棋子
private int[] bitRanks;//[10]方便按列位横线查询
private BitBoard[] pieceBits;//[14]分兵种及红黑的棋子位棋盘
private BitBoard allPieces;//整个棋盘
// Zobrist Key and Lock
private long zobristKey zobristLock;
// History MoveNodes用来作为循环重复检测
private int moveNum;
MoveNode[] moveList;//[ChessStruct.MaxMoveNum];
char[] loopHash;//[LoopHashMask + 1];
public ActiveBoard() {
int i;
player = 0;
evalue = new int[2];
evalue[0] = evalue[1] = 0;
squares = new int[90];
for (i = 0; i < 90; i ++) {
squares[i] = 0;
}
pieces = new int[48];
for (i = 16; i < 48; i ++) {
pieces[i] =
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
----------- --------- ---------- ----- ----
10025133 164
相关资源
- java多线程编程 在主线程main中创建两
- Aide直装模板
- 一站式Java网络编程 BIO-NIO-AIO资料源码
- JavaMail的JAR包
- 发邮件程序需要的:javax.mail包
- PyCharm SublimeText主题-monokai
- 使用Java mail API访问Lotus Domino邮箱
- JAVA开发的中国象棋游戏包括源码和需
- Java斗地主带AI版
- 八勺java斗地主AI版电脑智能拆牌
- UVPaint (Skinned Mesh Decal System) 1.84e.
- 中国象棋java版 保存 悔棋
- java邮件发送客户端
- 仅1500行的简易Java炸弹人游戏无AI(
- 中国象棋 java实现
- 中国象棋人机对弈Java版源码
- java中国象棋网络版源文件
- Android_Oaid.zip
- Airkiss一键配网小工具
- jai_imageio-1.1-alpha与Swingx-1.6.1的jar包
- Paint in 3D
- Java课程设计 源码彩色中国象棋游戏
- java实现象棋
- 腾讯身份证验证人脸识别代码java
- Java版中国象棋项目设计论文和源码
- JAVA项目-斗地主游戏 图形界面&&纸牌库
- 基于java的人脸识别系统+源码---百度
- 基于Android的五子棋开发
- tesseract-ocr 相关jar包 jar_jai_imageio-1.1
- android demo,ConstraintLayout 约束布局
评论
共有 条评论