js实现AI五子棋人机大战

本文实例为大家分享了js实现AI五子棋人机大战的具体代码,供大家参考,具体内容如下

实现原理就是计算五子棋所有赢的种类,利用canvas实现五子棋排版落子。

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <meta http-equiv="X-UA-Compatible" content="ie=edge">
 <title>五子棋</title>

 <style>
  #canvas{
   display: block;
   margin:50px auto;
   box-shadow: -2px -2px 2px #EFEFEF, 5px 5px 5px #b9b9b9;
  }
 </style>
</head>
<body>

 <canvas id="canvas" width="450px" height="450px"></canvas>

 <script>
 var canvas = document.getElementById('canvas');
 var context = canvas.getContext('2d');

 var me = true; //true黑子, false, 白子
 var over = false;
 var box = []; //全部落子点
 var wins = []; //全部赢的方法 三维数组

 for(var i = 0; i< 15 ;i++) {
  box[i] = [];
  wins[i] = [];
  for(var j = 0; j < 15; j++) {
   box[i][j] = 0;
   wins[i][j] = [];
  }
 }

 var count = 0; //总共赢的数量572种
 //横向
 for(var a = 0; a < 15; a++) {
  for(var b = 0; b < 11;b++) {
   //wins[0][0][0]
   //wins[0][1][0]
   //wins[0][2][0]
   for(var c = 0; c < 5;c++) {
    wins[a][b + c][count] = true;
   }
   count++;
  }
 }
 //纵向
 for(var a = 0; a < 15; a++) {
  for(var b = 0; b < 11;b++) {
   //wins[0][0][0]
   //wins[0][1][0]
   //wins[0][2][0]
   for(var c = 0; c < 5;c++) {
    wins[b + c][a][count] = true;
   }
   count++;
  }
 }

 //斜 '\'
 for(var a = 0; a < 11; a++) {
  for(var b = 0; b < 11;b++) {
   //a = 0, b = 10
   //win[0][10]
   //win[1][11]
   for(var c =0; c < 5;c++) {
    wins[a + c][b + c][count] = true;
   }
   count++;
  }
 }
 //反斜 '/'
 for(var a = 0; a < 11; a++) {
  for(var b = 4; b < 15;b++) {
   //a = 0, b = 0
   //win[0][5]
   //win[1][4]
   for(var c =0; c < 5;c++) {
    wins[a + c][b - c][count] = true;
   }
   count++;
  }
 }
 //我方、计算机方总共可以赢的数量,每在某一方式上可以赢的位置下一颗子,myWin[i]++
 //当myWin[i] == 5,说明我方在这个方式上赢的落子已经达到5颗,说明我方已经赢了
 var myWin = []; //
 var computerWin = [];
 for(var i = 0; i < count;i++) {
  myWin[i] = 0;
  computerWin[i] = 0;
 }

 //画纵横线条
 function drawLine() {

  context.strokeStyle = '#ccc';
  for(var i = 0; i < 15; i++) {
   context.moveTo(15 + 30 * i, 15);
   context.lineTo(15 + 30 * i, 435);
   context.stroke();

   context.moveTo(15, 15 + 30 * i);
   context.lineTo(435, 15 + 30 * i);
   context.stroke();
  }
 }
 drawLine()

 //走一步,画黑白子,并记录,黑子为1,白子为2
 function oneStep(i, j, me) {
  context.beginPath();
  context.arc(15 + i * 30, 15 + j*30, 13, 0, Math.PI * 2);
  context.closePath();

  var gradient = context.createRadialGradient(15 + i * 30 + 2, 15 + j*30 - 2, 13, 15 + i * 30 + 2, 15 + j*30 - 2, 0)
  if(me) { //黑子
   gradient.addColorStop(0, '#0A0A0A');
   gradient.addColorStop(1, '#636766');
   box[i][j] = 1;

  } else { //白子
   gradient.addColorStop(0, '#D1D1D1');
   gradient.addColorStop(1, '#F9F9F9');
   box[i][j] = 2;
  }
  context.fillStyle = gradient;
  context.fill();
 }

 canvas.onclick = function(e) {
  if(over) return;
  if(!me) return;
  var x = Math.floor(e.offsetX/30);
  var y = Math.floor(e.offsetY/30);
  if(box[x][y] == 0) { //判断没有落子
   oneStep(x, y, me);

   for(var k = 0; k<count; k++) {//第几种赢法
    if(wins[x][y][k]) {
     myWin[k]++;
     computerWin[k] = 6; //因为我方在这个点上已经落子,所以计算机不可能在这个点上赢,
     if(myWin[k] == 5) {
      console.log('你赢了')
      over = true;
     }
    }
   }
   if(!over) {
    me = !me;
    computerAI();
   }
  }
 }

 //计算机
 function computerAI() {
  var myScore = []; //我方分数
  var computerScore = []; //计算机分数
  var max = 0; //最大分数
  var u = 0, v = 0; //最大分数点
  for(var i =0; i < 15; i++) {
   myScore[i] = [];
   computerScore[i] = [];
   for(var j =0; j < 15; j++) {
    myScore[i][j] = 0;
    computerScore[i][j] = 0;
   }
  }

  for(var i =0; i < 15; i++) {
   for(var j =0; j < 15; j++) {
    if(box[i][j] == 0) { //每个空闲点上进行计算分数
     for(var k =0;k<count;k++) { //遍历所有可以赢的,数量
      if(wins[i][j][k]) { //可以赢的点进行算分

       if(myWin[k] == 1) {
        myScore[i][j] += 200;
       } else if(myWin[k] == 2) {
        myScore[i][j] += 400;
       } else if(myWin[k] == 3) {
        myScore[i][j] += 2000;
       } else if(myWin[k] == 4) {
        myScore[i][j] += 10000;
       }

       if(computerWin[k] == 1) {
        computerScore[i][j] += 220;
       } else if(computerWin[k] == 2) {
        computerScore[i][j] += 420;
       } else if(computerWin[k] == 3) {
        computerScore[i][j] += 2100;
       } else if(computerWin[k] == 4) {
        computerScore[i][j] += 20000;
       }
      }
     }

     //得出最大分数的点,并赋给u,v
     if(myScore[i][j] > max) {
      max = myScore[i][j];
      u = i;
      v = j;
     } else if(myScore[i][j] == max) {
      if(computerScore[i][j] > computerScore[u][v]) {
       u = i;
       v = j;
      }
     }

     if(computerScore[i][j] > max) {
      max = computerScore[i][j];
      u = i;
      v = j;
     } else if(computerScore[i][j] == max) {
      if(myScore[i][j] > myScore[u][v]) {
       u = i;
       v = j;
      }
     }

    }//所有空闲点上进行计算分数
   }
  }

  oneStep(u, v, false); //走一步

  for(var k = 0; k<count; k++) {//第几种赢法
   if(wins[u][v][k]) {
    computerWin[k]++;
    myWin[k] = 6;
    if(computerWin[k] == 5) {
     console.log('计算机赢了--')
     over = true;
    }
   }
  }

  if(!over) {
   me = !me;
  }

 } 

 </script>

</body>
</html>

效果图如下

实际操作效果还行,但相比真正ai实现还是有很多不足。

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

(0)

相关推荐

  • javascript 初学教程及五子棋小程序的简单实现

    一.JavaScript简介 JavaScript一种直译式脚本语言,是一种动态类型.弱类型.基于原型的语言,内置支持类型.它的解释器被称为JavaScript引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在HTML(标准通用标记语言下的一个应用)网页上使用,用来给HTML网页增加动态功能. 二.hbulider工具的使用 1) hbulider的特点: 1.飞快的编码速度 2.HBuilder直接创建移动App,打包为ios或Android原生安装包 3.HTML5语法.HTML5+

  • 原生JS+Canvas实现五子棋游戏

    本文实例为大家分享了JS  Canvas实现五子棋游戏的具体代码,供大家参考,具体内容如下 <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>五子棋</title> <style type='text/css'> canvas { display: block; margin: 50px auto; box-shadow: -2p

  • Javascript和HTML5利用canvas构建Web五子棋游戏实现算法

    这只是一个简单的JAVAscript和HTML5小程序,没有实现人机对战. 五子棋棋盘落子点对应的二维数组.数组的元素对应落子点.比如数组元素值为0表示该元素对应的落子点没有棋子,数组元素值为1表示该元素对应的落子点有白棋子,数组元素值为2表示该元素对应的落子点有黑棋子: 判断五子棋赢棋的算法是通过对五子棋棋盘落子点对应的二维数组的操作来实现的. 判断五子棋赢棋算法 下边的函数可以实现判断五子棋赢棋的算法,也可以按照教材中相应的算法实现. 其中函数的参数xx.yy为数组下标,chess数组实现五

  • 原生JS+Canvas实现五子棋游戏实例

    一.功能模块 先看下现在做完的效果: 线上体验:https://wj704.github.io/five_game.html 主要功能模块为: 1.人机对战功能 2.悔棋功能 3.撤销悔棋功能 二.代码详解 2.1 人机对战功能实现 从效果图可以看到,棋盘的横竖可以放的位置为15*15,通过canvas画棋盘: //绘画棋盘 var drawChessBoard = function(){ for(var i = 0; i < 15; i++){ context.moveTo(15 + i *

  • JS+canvas实现的五子棋游戏【人机大战版】

    本文实例讲述了JS+canvas实现的五子棋游戏.分享给大家供大家参考,具体如下: 运行效果图: html代码如下: <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>五子棋</title> <link rel="stylesheet" type="text/css" href="css

  • node.js利用socket.io实现多人在线匹配联机五子棋

    项目地址,已上传github --> client端使用简单的h5+js实现了棋局的总体布局. server端使用node的socket.io模块与客户端进行数据交互,棋子的落点和输赢校验均是在server端完成. 五子棋ui界面请见.. client端的界面这里就不做过多解释了,只要稍微懂点h5就可以自行去这里 下载源代码观看,因为今天的主题主要是socket.io这一块,所以本章只概述client和server是如何通过tcp连接进行交互的. 首先先带大家看一下目录结构 | server.j

  • H5+C3+JS实现五子棋游戏(AI篇)

    本文实例为大家分享了H5+C3+JS实现五子棋游戏的具体代码,供大家参考,具体内容如下 新增全局变量 <script> //所有赢法总和 var count = 0; //容纳所有赢法的三维数组 var allWin = []; for(var i =0; i <15; i++){ allWin[i] = []; for(var j=0; j <15; j++){ allWin[i][j] = []; } } //横线赢法 for(var i =0; i <15; i++){

  • 纯JS实现五子棋游戏兼容各浏览器(附源码)

    纯JS五子棋(各浏览器兼容) 效果图:  代码下载 HTML代码 复制代码 代码如下: <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html;"> <title>五子棋</title> <link rel="stylesheet" type="text/

  • JavaScript实现五子棋游戏的方法详解

    本文实例讲述了JavaScript实现五子棋游戏的方法.分享给大家供大家参考,具体如下: 最近半个月一直在看深入的学习JavaScript,里面有很多重点和难点,比如闭包.词法分析.面向对象等.今天给大家分享一个由JavaScript编写的五子棋游戏,主要用到JavaScript的面向对象.事件委托.闭包等知识,还是挺有分量的,正好可以检测学习的成果. 老规矩,先上图,再说话. 效果图: 五子棋素材图: 代码: <!DOCTYPE html> <html> <head>

  • H5+C3+JS实现双人对战五子棋游戏(UI篇)

    本篇文章实现的是双人对战模式,主要是实现除人机AI算法和判断输赢之外的其他功能,下一篇将会发布AI 框架搭建 <!Doctype html> <html> <head> <!-- 百度爬虫优化 --> <meta http-equiv="author" content="成兮,缘分五月" /> <meta http-equiv="Keywords" cotent="五子棋

  • 基于JavaScript实现五子棋游戏

    本文实例为大家分享了js实现五子棋的具体代码,供大家参考,具体内容如下 思路: 1.先用canvas画五子棋的棋盘 2.获取鼠标点击的位置 3.根据鼠标点击的位置判断,并画棋子 4.根据下的棋子判断是否赢了 代码: <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> <style>

  • JS canvas绘制五子棋的棋盘

    本文为大家分享了JS canvas绘制五子棋棋盘的具体代码,供大家参考,具体内容如下 box-shadow:给元素块周边添加阴影效果. 语法:box-shadow: h-shadow v-shadow blur spread color inset: h-shadow: (必须)阴影的水平偏移量,如果是正值,则阴影在元素块右边:如果是负值,则阴影在元素块左边. v-shadow: (必须)阴影的垂直偏移量,如果是正值,则阴影在元素块底部:如果是负值,则阴影在元素块顶部. blur: (可选)阴影

随机推荐