二维数组的定义 , canvas对象的使用

二维数组:以下用new,其实简化 [] 即可,

var tArray = new Array();  //先声明一维
for(var k=0;k<i;k++){ //一维长度为i,i为变量,可以根据实际情况改变
tArray[k]=new Array(); //声明二维,每一个一维数组里面的一个元素都是一个数组;
for(var j=0;j<p;j++){ //一维数组里面每个元素数组可以包含的数量p,p也是一个变量;
tArray[k][j]=""; //这里将变量初始化,我这边统一初始化为空,后面在用所需的值覆盖里面的值
}
}

--------
for(var a=0;a<i;a++){

tArray[a]=[ matArray[a],addArray[a] ];  两个 组成一个二维数组

};

 
var tArray = new Array();  //先声明一维
for(var k=0;k<i;k++){ //一维长度为i,i为变量,可以根据实际情况改变 tArray[k]=new Array(); //声明二维,每一个一维数组里面的一个元素都是一个数组; for(var j=0;j<p;j++){ //一维数组里面每个元素数组可以包含的数量p,p也是一个变量; tArray[k][j]=""; //这里将变量初始化,我这边统一初始化为空,后面在用所需的值覆盖里面的值
}
}

五子棋代码如下:曾经把它看懂,现在再看感觉又有点忘了,尴尬  2018-11-26 16:57:07

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>人工智能五子棋</title>
<meta charset="UTF-8" />
<meta name="author" content="张" />
<meta name="keywords" content="五子棋" />
<meta name="description" content="五子棋" />
<style>
*{margin:0;}
canvas{
background:#fff;margin:120px auto;display:block;border-radius:4px;box-shadow:0px 0px 10px #000;
}
</style>
</head>
<body>
<canvas width="450" height="450" id="canvas"></canvas>
<script> var over = false; var chess = document.getElementById("canvas");
//拿到权限 上下文 2d平面
var context = chess.getContext("2d"); context.strokeStyle="#a8a8a8";
//定义方法
var drawChessboard = function(){
//线条 起点终点坐标(x,y)
/*
context.moveTo(0,0);//起点坐标
context.lineTo(450,450);//终点坐标
context.stroke();//两点坐标相连
*/
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();
}
}
drawChessboard(); //绘制棋子
var onStep = function(i,j,me) {
//绘制棋子 圆形 圆心(x,y) 半径
//开始路径 区分大小写
context.beginPath();
context.arc(15+i*30,15+j*30,13,0,Math.PI*2);
//结束路径
context.closePath(); //渐变色 看文档,两个圆心 半径,
var gradient = context.createRadialGradient(15+i*30,15+j*30,0,15+i*30,15+j*30,13);
if (me) {
gradient.addColorStop(0,"#0a0a0a");
gradient.addColorStop(1,"#636363");
} else {
gradient.addColorStop(0,"#d1d1d1");
gradient.addColorStop(1,"#f9f9f9");
}
//填充颜色
context.fillStyle=gradient;
context.fill();
context.stroke();
} //建立一个二维数组判断棋盘上的落子情况
var chessBoard = [];
//把棋盘上面所有的点全部存进去
for (var i=0; i<15; i++) {
chessBoard[i] = []; //一维中存入还是数组
for (var j=0; j<15; j++) {
chessBoard[i][j] = 0;//等于0的地方没有下棋
}
} //下棋
var me = true;
chess.onclick = function(e) {
if(over) {
return false;
}
if(!me) {
return false;
}
//获取鼠标坐标
var x = e.offsetX;
var y = e.offsetY;
//点击范围30都可以下棋 向下取整
var i = Math.floor(x/30);
var j = Math.floor(y/30);
//把落的子放到数组中存储
if (chessBoard[i][j] == 0) { onStep(i,j,me);
chessBoard[i][j] = 1; for (var k=0; k<count; k++) {
if (wins[i][j][k]) {
//* 这里应该加多一个判断myWin[k]等于或大于6了,直接不用往下操作了。
if(myWin[k]!=6){
myWin[k]++;
computerWin[k] = 6;
if (myWin[k] == 5) {
alert("恭喜你赢了!");
over = true;
}
}
}
}
if (!over) {
me = !me;
computerAI();
}
}
} //统计赢法的种类
var wins = [];
//遍历棋盘
for (var i=0;i<15;i++) {
wins[i] = [];
for (var j=0; j<15; j++) {
wins[i][j] = [];
}
} //赢法的索引
var count = 0; //横线赢
for (var i=0; i<15; i++) {
for (var j=0; j<11; j++) {
for (var k=0; k<5; k++) {
wins[i][j+k][count] = true;
}
count++;
}
}
//竖线赢
for (var i=0; i<15; i++) {
for (var j=0; j<11; j++) {
for (var k=0; k<5; k++) {
wins[j+k][i][count] = true;
}
count++;
}
}
//斜线赢
for (var i=0; i<11; i++) {
for (var j=0; j<11; j++) {
for (var k=0; k<5; k++) {
wins[i+k][j+k][count] = true;
}
count++;
}
}
//反斜线赢
for (var i=0; i<11; i++) {
for (var j=14; j>3; j--) {
for (var k=0; k<5; k++) {
wins[i+k][j-k][count] = true;
}
count++;
}
}
//本棋盘 有572中赢发,
//统计赢法组
var myWin = [];//全局,用于记录 每在此赢法上下子一个即加一,判断每一种赢法是否达到了5,
var computerWin = [];
for (var i=0; i<count; i++) {
myWin[i] = 0;
computerWin[i] = 0;
} //计算机AI算法
var computerAI = function () {
//统计分数
var mySource = [];//局部数组,我方分数,每次计算机下棋都计算一遍
var computerSource = [];//计算机分数
var max = 0; //最高点分数
var u = 0,v = 0;//最高点分数坐标
//初始化我方和计算机分数
for (var i=0; i<15; i++) {
mySource[i] = [];
computerSource[i] = [];
for (var j=0; j<15; j++) {
mySource[i][j] = 0;
computerSource[i][j] = 0;
}
}
for (var i=0; i<15; i++) {
for (var j=0; j<15; j++) { //这里的两个for是遍历棋盘
if (chessBoard[i][j] == 0) {//这里对每一个没有下过子的 坐标分析,计算该落子的可能性多大
for (var k=0; k<count; k++) { //遍历所有赢法 572钟
if (wins[i][j][k]) { //遍历和该坐标有关的赢法,有关往下执行
if (myWin[k] == 1) { //若该赢法上 落子为1,加一定的分数;myWin[k]这个值是在我方下棋时累加的
mySource[i][j] += 200;
} else if (myWin[k] == 2) { //若该赢法上 落子为2,再加一定的分数
mySource[i][j] += 400;
} else if (myWin[k] == 3) { //若该赢法上 落子为3,再加一定的分数
mySource[i][j] += 2000;
} else if (myWin[k] == 4) {
mySource[i][j] += 10000;
} if (computerWin[k] == 1) { //同理,对计算机下的期判断,累加分数
computerSource[i][j] += 420;
} else if (computerWin[k] == 2) {
computerSource[i][j] += 820;
} else if (computerWin[k] == 3) {
computerSource[i][j] += 4100;
} else if (computerWin[k] == 4) {
computerSource[i][j] += 20000;
}
}
}
if (mySource[i][j] > max) { //这个坐标对于我赢的概率和之前最大的比
max = mySource[i][j];
u = i;
v = j;
} else if (mySource[i][j] == max) {//如果两个点对自己相同,那两个点对敌方哪个更有利?
if (computerSource[i][j]>computerSource[u][v]) {
u = i;
v = j;
}
} if (computerSource[i][j] > max) { //这个坐标对于计算机的概率和之前最大的比
max = computerSource[i][j];
u = i;
v = j;
} else if (computerSource[i][j] == max) {
if (mySource[i][j]>mySource[u][v]) {
u = i;
v = j;
}
}
}
}
}
onStep(u,v,false);
chessBoard[u][v] = 2;
for (var k=0; k<count; k++) {
if (wins[u][v][k]) {
//* 这里应该加多一个判断computerWin[k]等于或大于6了,直接不用往下操作了。
if(computerWin[k]!=6){
computerWin[k]++;
myWin[k] = 6;
if (computerWin[k] == 5) {
alert("计算机赢了!");
over = true;
}
} }
}
if (!over) {
me = !me;
}
} </script>
</body>
</html>

五子棋.html的更多相关文章

  1. 自己写的HTML5 Canvas + Javascript五子棋

    看到一些曾经只会灌水的网友,在学习了前端之后,已经能写出下载量几千几万的脚本.样式,帮助大众,成为受欢迎的人,感觉满羡慕的.我也想学会前端技术,变得受欢迎呀.于是心血来潮,开始学习前端知识,并写下了这 ...

  2. java swing 双人五子棋源代码

    import java.awt.Color; import java.awt.Font; import java.awt.Graphics; import java.awt.Toolkit; impo ...

  3. HTML5 五子棋 - JS/Canvas 游戏

    背景介绍 因为之前用c#的winform中的gdi+,java图形包做过五子棋,所以做这个逻辑思路也就驾轻就熟,然而最近想温故html5的canvas绘图功能(公司一般不用这些),所以做了个五子棋,当 ...

  4. [收藏]C++简单五子棋

    #include<iostream> #include<iomanip> using namespace std; ; //棋盘行数 ; //棋盘列数 char p[X][Y] ...

  5. jQuery网页版五子棋小游戏源码下载

    体验效果:http://hovertree.com/texiao/game/4/ 网页五子棋源代码: <!DOCTYPE html> <html> <head> & ...

  6. js+html5双人五子棋(源码下载)

    代码如下: <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" c ...

  7. jquery在线五子棋

    在线五子棋试玩地址:http://keleyi.com/game/12/ 以下是完整代码,保存到html文件打开也可以玩: <!DOCTYPE html> <html> < ...

  8. 五子棋AI清月连珠开源

    经过差不多两年的业余时间学习和编写,最近把清月连珠的无禁手部分完善得差不多了.这中间进行了很多思考,也有很多错误认识,到现在有一些东西还没有全面掌握,所以想通过开源于大家共同交流. 最近一直发表一些五 ...

  9. PyQt写的五子棋

    技术路线 GUI的实现 使用PyQt技术作为基础.PyQt是一个支持多平台的客户端开发SDK,使用它实现的客户端可以运行在目前几乎所有主流平台之上. 使用PyQt,Qt设计器实现UI,通过pyuic4 ...

  10. 浅析基本AI五子棋算法

    五子棋是所有棋类博弈中比较简单的了,这里介绍的也只是一种非常基本的AI策略.其实,包括之前的AI贪吃蛇,感觉这两个AI其实体现的都是一种建模思想,把一个现实中的问题模型化,抽象化,得到其一般特征,再设 ...

随机推荐

  1. 《通过C#学Proto.Actor模型》之Mailbox

    邮箱是Actor模型的一个重要组成部分,负责接收发过来的消息,并保存起来,等待Actor处理.邮箱中维护着两种队列,一种是存系统消息,另一个是存用户消息,系统省是指Started,Stoping,St ...

  2. 几种c++字符串split 函数实现的比较

    文中的字符串split函数功能是 从字符串中按照特定的分隔符进行分割,分割的结果保存到std::vector中. 1. strtok实现 std::vector<std::string> ...

  3. GEC6818连接Ubuntu,下载程序至开发板

    使用  secure CRT连接开发板,可视化操作 连接成功 设置临时ip ubuntu 要跟 开发板同一网段: ip前三位相同 代码:sudo service tftpd-hpa restart 代 ...

  4. codeforces#1011C. Fly (二分,注意精度)

    题意:火箭经过1到n号星球,并回到1号星球,现在给出每消耗一砘燃油能带起的火箭质量a[i]和b[i],a[i]代表在第i个星球起飞,b[i]代表在第i个星球降落.求出最少消耗的汽油.保证:如果不能完成 ...

  5. 记一次innobackupex备份恢复数据库过程

    简介:以前备份都是通过mysqldump备份数据库的,由于是逻辑备份,所以采用这种备份方式数据是很安全的,跨平台.版本都很容易.凡事有利必有弊,逻辑备份在你数据库比较大时,备份.恢复数据所耗费的时间也 ...

  6. Jekins相关笔记

    Jekins忘记密码操作 https://blog.csdn.net/intelrain/article/details/78749635 Jekins重启 https://www.cnblogs.c ...

  7. python 爬取可用

    #coding:utf-8 from bs4 import BeautifulSoup import time import threading import random import telnet ...

  8. LODOP不同打印机出现偏移问题

    方法简单描述:1.精确套打,设置以纸张边缘为基点,可避免不同可打区域不同带了的影响.2.不同客户端打印机位置差异,可通过打印维护调整,结果在客户端本地.或调整打印机初始位置(本人使用的金税盘的开票软件 ...

  9. MySQL聚簇索引和非聚簇索引的对比

    首先要清楚:聚簇索引并不是一种单独的索引类型,而是一种存储数据的方式. 聚簇索引在实际中用的很多,Innodb就是聚簇索引,Myisam 是非聚簇索引. 在之前我想插入一段关于innodb和myisa ...

  10. SVD/SVD++实现推荐算法

    奇异值分解(Singular Value Decomposition,以下简称SVD)是在机器学习领域广泛应用的算法,它不仅可以用于降维算法中的特征分解,还可以用于推荐系统,以及自然语言处理等领域. ...