前面我们已经画好棋盘和棋子,并可以自由落子,且可以判断棋盘中是否有五连珠。接下来的工作是,每次落子后交换行棋方(即将下一棋子颜色由白->黑或黑->白),并将胜出判断增加颜色判断条件(棋盘上存在五连珠->棋盘上存在同色的五连珠)。

主模块Main.java和棋子类Chessman.java不变,我们要对DrawChessBoard.java中的落子函数mousePressed和五连珠判断函数isWin做一下调整。

Main.java

package xchen.test.simpleGobang;

import java.awt.Container;

import javax.swing.JFrame;

import xchen.test.simpleGobang.DrawChessBoard;

public class Main extends JFrame{

private DrawChessBoard drawChessBoard;

public Main() {

drawChessBoard = new DrawChessBoard();

//Frame标题

setTitle("单机五子棋");

Container containerPane =getContentPane();

containerPane.add(drawChessBoard);

}

public static void main(String[] args) {

Main m = new Main();

m.setSize(800, 800);

m.setVisible(true);

}

}

Chessman.java

package xchen.test.simpleGobang;

public class Chessman {

private int color;//1-white,0-black

private boolean placed = false;

int matchCount = 1;

public Chessman(int color,boolean placed){

this.color=color;

this.placed=placed;

}

public boolean getPlaced() {

return placed;

}

public void setPlaced(boolean placed) {

this.placed = placed;

}

public int getColor() {

return color;

}

public void setColor(int color) {

this.color = color;

}

}

第一步,修改mousePressed函数,使得每次落子后,都将行棋方让给对家(即每次落子都改变棋子颜色)

DrawChessBoard.java中的mousePressed函数部分,只要每次都修改chessColor的值即可。

@Override

//当用户按下鼠标按钮时发生

public void mousePressed(MouseEvent e) {

int point_x=e.getX();

int point_y=e.getY();

int imgWidth = boardImg.getHeight(this);

int imgHeight = boardImg.getWidth(this);

int FWidth = getWidth();

int FHeight= getHeight();

int x=(FWidth-imgWidth)/2;

int y=(FHeight-imgHeight)/2;

int span_x=imgWidth/ROWS;

int span_y=imgHeight/ROWS;

//System.out.println("press");

int status_x = 0;

int status_y = 0;

if(point_x>=x && point_x<=x+imgWidth && point_y>=y && point_y <= y+imgHeight)

{

//System.out.println("合法");

for(int i=0;i

{

if(point_x>=x-chessman_width/2+1+i*span_x)

{

if(point_x<=x+chessman_width/2-1+i*span_x)//如果是width/2会在中间点出现两个匹配值

{

//System.out.println("point x "+i+" "+point_x+" "+(x-chessman_width/2+i*span_x)+" "+(x+chessman_width/2+i*span_x));

status_x = i;

}

}

}

for(int i=0;i

{

if(point_y>=y-chessman_width/2+1+i*span_y)

{

if(point_y <= y+chessman_width/2-1+i*span_y)

{

//System.out.println("point y "+i+" "+point_y+" "+(y-chessman_width/2+1+i*span_y)+" "+(y+chessman_width/2-1+i*span_y));

status_y = i;

}

}

}

Chessman chessman = new Chessman(chessColor, true);

chessStatus[status_x][status_y]=chessman;

System.out.println("chess color:"+chessColor);

if(chessColor==BLACK)

{

chessColor = WHITE;

}else {

chessColor = BLACK;

}

repaint();

if(isWin(status_x, status_y, chessStatus))

{

System.out.println("WIN!!!!!");

}

}

}

运行一下

第二步,将胜出判断增加颜色判断条件(棋盘上存在五连珠->棋盘上存在同色的五连珠)

在isWin函数的判断条件上,加上对Chessman.getColor的颜色判断

isWin函数代码

boolean isWin(int point_x,int point_y,Chessman[][] cm)

{

for(int i=0;i

{

for(int j=0;j

{

//横向查找

if(chessStatus[i][j]!=null&&chessStatus[i][j].getPlaced()==true)

{

int matchColor = chessStatus[i][j].getColor();

//向右侧查找

for(int n=1;n<=4;n++)

{

if((i+n>=0)&&(i+n)<=ROWS)

{

if(chessStatus[i+n][j]!=null&&chessStatus[i+n][j].getPlaced()==true&&chessStatus[i+n][j].getColor()==matchColor)

{

chessStatus[i][j].matchCount++;

System.out.println("pos:"+i+" "+j+" right count++:"+(i+n)+" "+j+" count:"+chessStatus[i][j].matchCount);

if(chessStatus[i][j].matchCount==5)

{

return true;

}

}else

{

break;

}

}

}

//向左侧查找

for(int n=1;n<=4;n++)

{

if((i-n>=0)&&(i-n)<=ROWS)

{

if(chessStatus[i-n][j]!=null&&chessStatus[i-n][j].getPlaced()==true&&chessStatus[i-n][j].getColor()==matchColor)

{

chessStatus[i][j].matchCount++;

System.out.println("pos:"+i+" "+j+" "+"left count++:"+(i-n)+" "+j+" count:"+chessStatus[i][j].matchCount);

if(chessStatus[i][j].matchCount==5)

{

return true;

}

}else

{

if(chessStatus[i-n][j]!=null)

{

chessStatus[i][j].matchCount = 1;

}

break;

}

}

}

chessStatus[i][j].matchCount=1;//refresh count

}

}

}

for(int i=0;i

{

for(int j=0;j

{

//纵向

if(chessStatus[i][j]!=null&&chessStatus[i][j].getPlaced()==true)

{

int matchColor = chessStatus[i][j].getColor();

//向下查找,左上角为坐标原点,y轴正方向向下

for(int n=1;n<=4;n++)

{

if((j+n>=0)&&(j+n)<=ROWS)

{

if(chessStatus[i][j+n]!=null&&chessStatus[i][j+n].getPlaced()==true&&chessStatus[i][j+n].getColor()==matchColor)

{

chessStatus[i][j].matchCount++;

System.out.println("pos:"+i+" "+j+" up count++:"+(i)+" "+(j+n)+" count:"+chessStatus[i][j].matchCount);

if(chessStatus[i][j].matchCount==5)

{

return true;

}

}else

{

break;

}

}

}

//向上查找

for(int n=1;n<=4;n++)

{

if((j-n>=0)&&(j-n)<=ROWS)

{

if(chessStatus[i][j-n]!=null&&chessStatus[i][j-n].getPlaced()==true&&chessStatus[i][j-n].getColor()==matchColor)

{

chessStatus[i][j].matchCount++;

System.out.println("pos:"+i+" "+j+" "+"left count++:"+(i)+" "+(j-n)+" count:"+chessStatus[i][j].matchCount);

if(chessStatus[i][j].matchCount==5)

{

return true;

}

}else

{

if(chessStatus[i][j-n]!=null)

{

chessStatus[i][j].matchCount = 1;

}

break;

}

}

}

chessStatus[i][j].matchCount=1;//refresh count

}

}

}

//方向:左上右下

for(int i=0;i

{

for(int j=0;j

{

//左上

if(chessStatus[i][j]!=null&&chessStatus[i][j].getPlaced()==true)

{

int matchColor = chessStatus[i][j].getColor();

//向下查找,左上角为坐标原点,y轴正方向向下

for(int n=1;n<=4;n++)

{

if((j-n>=0)&&(j-n)<=ROWS&&(i-n)>=0&&(i-n)<=ROWS)

{

if(chessStatus[i-n][j-n]!=null&&chessStatus[i-n][j-n].getPlaced()==true&&chessStatus[i-n][j-n].getColor()==matchColor)

{

chessStatus[i][j].matchCount++;

System.out.println("pos:"+i+" "+j+" up count++:"+(i-n)+" "+(j-n)+" count:"+chessStatus[i][j].matchCount);

if(chessStatus[i][j].matchCount==5)

{

return true;

}

}else

{

break;

}

}

}

//右下

for(int n=1;n<=4;n++)

{

if((j+n>=0)&&(j+n)<=ROWS&&(i+n)>=0&&(i+n)<=ROWS)

{

if(chessStatus[i+n][j+n]!=null&&chessStatus[i+n][j+n].getPlaced()==true&&chessStatus[i+n][j+n].getColor()==matchColor)

{

chessStatus[i][j].matchCount++;

System.out.println("pos:"+i+" "+j+" "+"left count++:"+(i+n)+" "+(j+n)+" count:"+chessStatus[i][j].matchCount);

if(chessStatus[i][j].matchCount==5)

{

return true;

}

}else

{

if(chessStatus[i+n][j+n]!=null)

{

chessStatus[i][j].matchCount = 1;

}

break;

}

}

}

chessStatus[i][j].matchCount=1;//refresh count

}

}

}

//方向:左下右上

for(int i=0;i

{

for(int j=0;j

{

//左下

if(chessStatus[i][j]!=null&&chessStatus[i][j].getPlaced()==true)

{

int matchColor = chessStatus[i][j].getColor();

//向下查找,左上角为坐标原点,y轴正方向向下

for(int n=1;n<=4;n++)

{

if((j+n>=0)&&(j+n)<=ROWS&&(i-n)>=0&&(i-n)<=ROWS)

{

if(chessStatus[i-n][j+n]!=null&&chessStatus[i-n][j+n].getPlaced()==true&&chessStatus[i-n][j+n].getColor()==matchColor)

{

chessStatus[i][j].matchCount++;

System.out.println("pos:"+i+" "+j+" up count++:"+(i-n)+" "+(j+n)+" count:"+chessStatus[i][j].matchCount);

if(chessStatus[i][j].matchCount==5)

{

return true;

}

}else

{

break;

}

}

}

//右上

for(int n=1;n<=4;n++)

{

if((j-n>=0)&&(j-n)<=ROWS&&(i+n)>=0&&(i+n)<=ROWS)

{

if(chessStatus[i+n][j-n]!=null&&chessStatus[i+n][j-n].getPlaced()==true&&chessStatus[i+n][j-n].getColor()==matchColor)

{

chessStatus[i][j].matchCount++;

System.out.println("pos:"+i+" "+j+" "+"left count++:"+(i+n)+" "+(j-n)+" count:"+chessStatus[i][j].matchCount);

if(chessStatus[i][j].matchCount==5)

{

return true;

}

}else

{

if(chessStatus[i+n][j-n]!=null)

{

chessStatus[i][j].matchCount = 1;

}

break;

}

}

}

chessStatus[i][j].matchCount=1;//refresh count

}

}

}

return false;

}

运行一下!

完整的DrawChessBoard.java

package xchen.test.simpleGobang;

import java.awt.Color;

import java.awt.Graphics;

import java.awt.Graphics2D;

import java.awt.Image;

import java.awt.RadialGradientPaint;

import java.awt.Toolkit;

import java.awt.event.MouseEvent;

import java.awt.event.MouseListener;

import javax.swing.JPanel;

public class DrawChessBoard extends JPanel implements MouseListener{

final static int BLACK=0;

final static int WHITE=1;

public int chessColor = BLACK;

int chessman_width=30;

public Image boardImg;

final private int ROWS = 19;

Chessman[][] chessStatus=new Chessman[ROWS+1][ROWS+1];

public DrawChessBoard() {

boardImg = Toolkit.getDefaultToolkit().getImage("res/drawable/chessboard2.png");

if(boardImg == null)

System.err.println("png do not exist");

addMouseListener(this);

}

@Override

protected void paintComponent(Graphics g) {

// TODO Auto-generated method stub

super.paintComponent(g);

int imgWidth = boardImg.getHeight(this);

int imgHeight = boardImg.getWidth(this);

int FWidth = getWidth();

int FHeight= getHeight();

int x=(FWidth-imgWidth)/2;

int y=(FHeight-imgHeight)/2;

int span_x=imgWidth/ROWS;

int span_y=imgHeight/ROWS;

g.drawImage(boardImg, x, y, null);

//画横线

for(int i=0;i

{

g.drawLine(x, y+i*span_y, FWidth-x,y+i*span_y);

}

//画竖线

for(int i=0;i

{

g.drawLine(x+i*span_x, y, x+i*span_x,FHeight-y);

}

//画棋子

for(int i=0;i

{

for(int j=0;j

{

if(chessStatus[i][j]!=null&&chessStatus[i][j].getPlaced()==true)

{

//System.out.println("draw chessman "+i+" "+j);

int pos_x=x+i*span_x;

int pos_y=y+j*span_y;

float radius_b=40;

float radius_w=80;

float[] fractions = new float[]{0f,1f};

java.awt.Color[] colors_b = new java.awt.Color[]{Color.BLACK,Color.WHITE};

Color[] colors_w = new Color[]{Color.WHITE,Color.BLACK};

RadialGradientPaint paint;

if(chessStatus[i][j].getColor()==1)

{

//System.out.println("draw white chess");

paint = new RadialGradientPaint(pos_x-chessman_width/2f, pos_y-chessman_width/2f, radius_w*2, fractions, colors_w);

}else{

//System.out.println("draw black chess");

paint = new RadialGradientPaint(pos_x-chessman_width/2f, pos_y-chessman_width/2f, radius_b*2, fractions, colors_b);

}

((Graphics2D)g).setPaint(paint);

((Graphics2D)g).fillOval(pos_x-chessman_width/2,pos_y-chessman_width/2,chessman_width,chessman_width);

}

}

}

}

@Override

//当用户按下鼠标按钮时发生

public void mousePressed(MouseEvent e) {

int point_x=e.getX();

int point_y=e.getY();

int imgWidth = boardImg.getHeight(this);

int imgHeight = boardImg.getWidth(this);

int FWidth = getWidth();

int FHeight= getHeight();

int x=(FWidth-imgWidth)/2;

int y=(FHeight-imgHeight)/2;

int span_x=imgWidth/ROWS;

int span_y=imgHeight/ROWS;

//System.out.println("press");

int status_x = 0;

int status_y = 0;

if(point_x>=x && point_x<=x+imgWidth && point_y>=y && point_y <= y+imgHeight)

{

//System.out.println("合法");

for(int i=0;i

{

if(point_x>=x-chessman_width/2+1+i*span_x)

{

if(point_x<=x+chessman_width/2-1+i*span_x)//如果是width/2会在中间点出现两个匹配值

{

//System.out.println("point x "+i+" "+point_x+" "+(x-chessman_width/2+i*span_x)+" "+(x+chessman_width/2+i*span_x));

status_x = i;

}

}

}

for(int i=0;i

{

if(point_y>=y-chessman_width/2+1+i*span_y)

{

if(point_y <= y+chessman_width/2-1+i*span_y)

{

//System.out.println("point y "+i+" "+point_y+" "+(y-chessman_width/2+1+i*span_y)+" "+(y+chessman_width/2-1+i*span_y));

status_y = i;

}

}

}

if(chessStatus[status_x][status_y]==null||chessStatus[status_x][status_y].getPlaced()==false)

{

Chessman chessman = new Chessman(chessColor, true);

chessStatus[status_x][status_y]=chessman;

System.out.println("chess color:"+chessColor);

if(chessColor==BLACK)

{

chessColor = WHITE;

}else {

chessColor = BLACK;

}

repaint();

if(isWin(status_x, status_y, chessStatus))

{

System.out.println("WIN!!!!!");

}

}

}

}

@Override

//当用户按下并松开鼠标按钮时发生

public void mouseClicked(MouseEvent e) {

// TODO Auto-generated method stub

}

@Override

public void mouseReleased(MouseEvent e) {

// TODO Auto-generated method stub

}

@Override

public void mouseEntered(MouseEvent e) {

// TODO Auto-generated method stub

}

@Override

public void mouseExited(MouseEvent e) {

// TODO Auto-generated method stub

}

boolean isWin(int point_x,int point_y,Chessman[][] cm)

{

for(int i=0;i

{

for(int j=0;j

{

//横向查找

if(chessStatus[i][j]!=null&&chessStatus[i][j].getPlaced()==true)

{

int matchColor = chessStatus[i][j].getColor();

//向右侧查找

for(int n=1;n<=4;n++)

{

if((i+n>=0)&&(i+n)<=ROWS)

{

if(chessStatus[i+n][j]!=null&&chessStatus[i+n][j].getPlaced()==true&&chessStatus[i+n][j].getColor()==matchColor)

{

chessStatus[i][j].matchCount++;

System.out.println("pos:"+i+" "+j+" right count++:"+(i+n)+" "+j+" count:"+chessStatus[i][j].matchCount);

if(chessStatus[i][j].matchCount==5)

{

return true;

}

}else

{

break;

}

}

}

//向左侧查找

for(int n=1;n<=4;n++)

{

if((i-n>=0)&&(i-n)<=ROWS)

{

if(chessStatus[i-n][j]!=null&&chessStatus[i-n][j].getPlaced()==true&&chessStatus[i-n][j].getColor()==matchColor)

{

chessStatus[i][j].matchCount++;

System.out.println("pos:"+i+" "+j+" "+"left count++:"+(i-n)+" "+j+" count:"+chessStatus[i][j].matchCount);

if(chessStatus[i][j].matchCount==5)

{

return true;

}

}else

{

if(chessStatus[i-n][j]!=null)

{

chessStatus[i][j].matchCount = 1;

}

break;

}

}

}

chessStatus[i][j].matchCount=1;//refresh count

}

}

}

for(int i=0;i

{

for(int j=0;j

{

//纵向

if(chessStatus[i][j]!=null&&chessStatus[i][j].getPlaced()==true)

{

int matchColor = chessStatus[i][j].getColor();

//向下查找,左上角为坐标原点,y轴正方向向下

for(int n=1;n<=4;n++)

{

if((j+n>=0)&&(j+n)<=ROWS)

{

if(chessStatus[i][j+n]!=null&&chessStatus[i][j+n].getPlaced()==true&&chessStatus[i][j+n].getColor()==matchColor)

{

chessStatus[i][j].matchCount++;

System.out.println("pos:"+i+" "+j+" up count++:"+(i)+" "+(j+n)+" count:"+chessStatus[i][j].matchCount);

if(chessStatus[i][j].matchCount==5)

{

return true;

}

}else

{

break;

}

}

}

//向上查找

for(int n=1;n<=4;n++)

{

if((j-n>=0)&&(j-n)<=ROWS)

{

if(chessStatus[i][j-n]!=null&&chessStatus[i][j-n].getPlaced()==true&&chessStatus[i][j-n].getColor()==matchColor)

{

chessStatus[i][j].matchCount++;

System.out.println("pos:"+i+" "+j+" "+"left count++:"+(i)+" "+(j-n)+" count:"+chessStatus[i][j].matchCount);

if(chessStatus[i][j].matchCount==5)

{

return true;

}

}else

{

if(chessStatus[i][j-n]!=null)

{

chessStatus[i][j].matchCount = 1;

}

break;

}

}

}

chessStatus[i][j].matchCount=1;//refresh count

}

}

}

//方向:左上右下

for(int i=0;i

{

for(int j=0;j

{

//左上

if(chessStatus[i][j]!=null&&chessStatus[i][j].getPlaced()==true)

{

int matchColor = chessStatus[i][j].getColor();

//向下查找,左上角为坐标原点,y轴正方向向下

for(int n=1;n<=4;n++)

{

if((j-n>=0)&&(j-n)<=ROWS&&(i-n)>=0&&(i-n)<=ROWS)

{

if(chessStatus[i-n][j-n]!=null&&chessStatus[i-n][j-n].getPlaced()==true&&chessStatus[i-n][j-n].getColor()==matchColor)

{

chessStatus[i][j].matchCount++;

System.out.println("pos:"+i+" "+j+" up count++:"+(i-n)+" "+(j-n)+" count:"+chessStatus[i][j].matchCount);

if(chessStatus[i][j].matchCount==5)

{

return true;

}

}else

{

break;

}

}

}

//右下

for(int n=1;n<=4;n++)

{

if((j+n>=0)&&(j+n)<=ROWS&&(i+n)>=0&&(i+n)<=ROWS)

{

if(chessStatus[i+n][j+n]!=null&&chessStatus[i+n][j+n].getPlaced()==true&&chessStatus[i+n][j+n].getColor()==matchColor)

{

chessStatus[i][j].matchCount++;

System.out.println("pos:"+i+" "+j+" "+"left count++:"+(i+n)+" "+(j+n)+" count:"+chessStatus[i][j].matchCount);

if(chessStatus[i][j].matchCount==5)

{

return true;

}

}else

{

if(chessStatus[i+n][j+n]!=null)

{

chessStatus[i][j].matchCount = 1;

}

break;

}

}

}

chessStatus[i][j].matchCount=1;//refresh count

}

}

}

//方向:左下右上

for(int i=0;i

{

for(int j=0;j

{

//左下

if(chessStatus[i][j]!=null&&chessStatus[i][j].getPlaced()==true)

{

int matchColor = chessStatus[i][j].getColor();

//向下查找,左上角为坐标原点,y轴正方向向下

for(int n=1;n<=4;n++)

{

if((j+n>=0)&&(j+n)<=ROWS&&(i-n)>=0&&(i-n)<=ROWS)

{

if(chessStatus[i-n][j+n]!=null&&chessStatus[i-n][j+n].getPlaced()==true&&chessStatus[i-n][j+n].getColor()==matchColor)

{

chessStatus[i][j].matchCount++;

System.out.println("pos:"+i+" "+j+" up count++:"+(i-n)+" "+(j+n)+" count:"+chessStatus[i][j].matchCount);

if(chessStatus[i][j].matchCount==5)

{

return true;

}

}else

{

break;

}

}

}

//右上

for(int n=1;n<=4;n++)

{

if((j-n>=0)&&(j-n)<=ROWS&&(i+n)>=0&&(i+n)<=ROWS)

{

if(chessStatus[i+n][j-n]!=null&&chessStatus[i+n][j-n].getPlaced()==true&&chessStatus[i+n][j-n].getColor()==matchColor)

{

chessStatus[i][j].matchCount++;

System.out.println("pos:"+i+" "+j+" "+"left count++:"+(i+n)+" "+(j-n)+" count:"+chessStatus[i][j].matchCount);

if(chessStatus[i][j].matchCount==5)

{

return true;

}

}else

{

if(chessStatus[i+n][j-n]!=null)

{

chessStatus[i][j].matchCount = 1;

}

break;

}

}

}

chessStatus[i][j].matchCount=1;//refresh count

}

}

}

return false;

}

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

java五子棋实验报告6_Java实现两人五子棋游戏(六) 行棋方变换相关推荐

  1. Java实现一个简单的两人五子棋游戏(六) 行棋方变换

    1)选择棋子 ✔️ 2)画棋子 ✔️ 3)判断胜负 ✔️ 4)交换行棋方 目标 前面我们已经画好棋盘和棋子,并可以自由落子,且可以判断棋盘中是否有五连珠.接下来的工作是,每次落子后交换行棋方(即将下一 ...

  2. c#五子棋实验报告_基于c#的五子棋游戏的设计与实现毕业论文.doc

    基于c#的五子棋游戏的设计与实现毕业论文 郑 州 科 技 学 院 课 程 设 计 论 文 基于C#的五子棋游戏的设计与实现 学生姓名:王新年 学 号:201015066 年级专业:10级计科二班 指导 ...

  3. c语言五子棋实验报告免费下载,C语言 五子棋程序

    C语言 五子棋程序 c语言五子棋程序 #include #include #include #include #include /*********************************** ...

  4. Java实现一个简单的两人五子棋游戏(一) 系统设计

    实现一个基本的单机五子棋功能 该五子棋棋盘大小为19*19的网格,玩家可以通过鼠标点击棋盘来落子,当出现五连珠时,提示一方胜出~ 1)模块划分 主模块:调用其他模块实现五子棋功能 棋盘模块:绘制五子棋 ...

  5. JavaFx/Java 大作业 五子棋 实验报告

    Java大作业五子棋实验报告 实验目的 通过此次实验,对这一学期学习的内容尤其是界面开发部分做了一个很好的回顾,看似简单的五子棋程序,设计好也确实费了我一点功夫 功能模块简介和系统结构图 ChessG ...

  6. 西电java实验报告 界面_西电计算机Java上机实验报告.docx

    西电计算机Java上机实验报告.docx 下载提示(请认真阅读)1.请仔细阅读文档,确保文档完整性,对于不预览.不比对内容而直接下载带来的问题本站不予受理. 2.下载的文档,不会出现我们的网址水印. ...

  7. Java程序设计实验报告 实验名称:循环和数组

    Java程序设计实验报告 实验名称:循环和数组 学号: 姓名:大聪TI学员 实验日期:2018年5月30日星期三 一.实验目的: 1. 遵循循环设计策略来开发循环,使用标记值控制循环. 2. 使用fo ...

  8. 计算器java程序设计报告总体设计,java程序设计实验报告-计算器

    <java程序设计实验报告-计算器>由会员分享,可在线阅读,更多相关<java程序设计实验报告-计算器(18页珍藏版)>请在金锄头文库上搜索. 1. Java 程序设计实验报告 ...

  9. java象棋实验报告_中国象棋java程序设计实验报告

    中国象棋java程序设计实验报告 东北大学秦皇岛分校信息与计算科学系Java 程序设计实验报告专业名称 信 息 与 计 算 科 学班级学号 7080206学生姓名 彭 军指导教师 王 薇完成时间 20 ...

最新文章

  1. CVPR2020论文点评: AdderNet(加法网络)
  2. 20175203 2018-2019 实验五《网络编程与安全》
  3. ubuntu mysql 远程连接问题解决方法
  4. 队列和通知区别_消息队列,阻塞队列
  5. 数学之美系列十七 -- 谈谈搜索引擎作弊问题(Search Engine Anti-SPAM)
  6. rpm包安装mysql5.5
  7. 内置函数之sorted,filter,map
  8. 最小路径覆盖,最小点覆盖,最大独立点集(转)
  9. Inno Setup 打包安裝判斷是否安裝.net freamework 3.5 和 access2007的數據連接
  10. sqrt numpy_NumPy sqrt()–矩阵元素的平方根
  11. conflicting declaration ‘typedef struct LZ4_stream_t LZ4_stream_t’解决
  12. 最新遥感图像解译标准数据集--202105
  13. 我的世界java出生蘑菇岛,《我的世界》出生就有蘑菇岛和海底神庙的地图,附近还有村庄!...
  14. 数据库开发常见面试题
  15. 2+22+222+2222+。。。。
  16. 使用内网服务器上线微信小程序总结
  17. 2022年PYTHON应用行业,PYTHON就业方向
  18. Keil出现.\Flash\Blinky.axf: error: L6002U: Could not open file .\flash\system_lpc11xx.o: No such file
  19. c语言求众数,众数求c++程序
  20. 游戏地图主要功能实现

热门文章

  1. 关于C++ STL 中advance()、 distance() 、begin()、end()、prev()、next() 函数的使用
  2. Problem A. MUV LUV EXTRA(kmp求最小循环节)
  3. 【组队学习】【36期】交大ACM算法课(C++)
  4. 福州市政府智慧城市部门分析
  5. php盯盘,盘口盯盘,你可能错过的六大秘密(图解)
  6. canvas绘制扇形,可以改变数量、扇形角度、扇形方向
  7. Windows下Qt拔插U盘的检测方法
  8. [灯火阑珊] 关于cmd命令里的findstr匹配多个关键词
  9. 智能制造技术基础复习内容全
  10. 老生常谈重放攻击的概念(必看篇)