javascript和HTML5利用canvas构建猜牌游戏实现算法


Posted in Javascript onJuly 17, 2013

让我猜猜你心中的牌,先随机生成27张牌,不能重复列出三列牌,然后记住其中一张,然后点击牌所在的列,多次就可以猜出你想的牌。
如果是9张只要猜2次,如果是27张就是猜3次。

实现方法(27张):
如果点击了第三列,那就是说牌一定在这9张里面,就把第三列的9张牌平均给每列分3张,假设编号为123,456,789
再点击一次,如果点击第二列,那么猜的牌就在456里面,再分到三列,4,5,6
再点击一次,就可以知道牌是哪个了。

实现算法:
我是使用一维数组实现,第一次猜第三列就把第三列的数据和0,1,2,3,4,5,6,7,8替换,
那么所猜的数就在前面9个,第二次猜第二列就把所在列的三个和0,1,2替换,那么就在前面三个了。
输出按照三列输出, 不过有个问题是,这样后面的牌就不会乱了,别人就知道你为什么猜到的了
所以在输出的时候就要乱序输出,只能够上下乱序输出,不能左右乱序
var random = new Array(5);//自定义二维乱序表
random[0] = [5, 2, 8, 7, 1, 3, 4, 6, 0];
random[1] = [2, 5, 8, 0, 4, 6, 3, 7, 1];
random[2] = [6, 7, 2, 8, 0, 1, 5, 3, 4];
random[3] = [2, 1, 6, 3, 5, 4, 7, 0, 8];
random[4] = [0, 1, 2, 3, 4, 5, 6, 7, 8];
更多请查看:www.shengshiyouxi.com
javascript和HTML5利用canvas构建猜牌游戏实现算法 

< !DOCTYPE html> 
< html xmlns="http://www.w3.org/1999/xhtml"> 
< head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title></title> 
<script type="text/JAVAscript"> 
var data = new Array(27); 
var canvas; 
var context; 
var time = 0; 
var random = new Array(5);//自定义二维乱序表 
random[0] = [5, 2, 8, 7, 1, 3, 4, 6, 0]; 
random[1] = [2, 5, 8, 0, 4, 6, 3, 7, 1]; 
random[2] = [6, 7, 2, 8, 0, 1, 5, 3, 4]; 
random[3] = [2, 1, 6, 3, 5, 4, 7, 0, 8]; 
random[4] = [0, 1, 2, 3, 4, 5, 6, 7, 8]; 
function start() { 
var guess = new Array(); 
var count = 0; 
while (count < 27) {//生成随机的27张牌 
var temp = parseInt(Math.random() * 54) + 1; 
for (var i = 0; i < count + 1; i++) { 
if (temp == guess) {//如果重复就不要 
temp = 100; 
break; 
} 
} 
if (temp != 100) { 
guess[count] = temp; 
data[count] = new Image(); 
data[count].src = "images/" + temp + ".gif"; 
count++; 
} 
} 
} 
function draw() { 
canvas = document.getElementById("canvas"); 
context = canvas.getContext("2d"); 
var temp1 = parseInt(Math.random() * 5); 
var temp2 = parseInt(Math.random() * 5); 
var temp3 = parseInt(Math.random() * 5); 
for (var i = 0; i < 9; i++) {//乱序排序方法 
context.drawImage(data[random[temp1] * 3 + 0], 20, i * 30 + 40); 
context.drawImage(data[random[temp2]* 3 + 1], 20 + 100, i * 30 + 40); 
context.drawImage(data[random[temp3]* 3 + 2], 20 + 200, i * 30 + 40); 
} 
} 
function play(index) { 
if (time >= 3) 
alert("请点击再来一次"); 
for (var i = 0; i < (3 - time) * 3; i++) { 
var temp = data; 
data= data[i * 3 + index - 1]; 
data[i * 3 + index - 1] = temp; 
} 
time++; 
if (time >= 3) { 
context.drawImage(data[0], 400, 50); 
return; 
} 
draw(); 
} 
start(); 
</script> 
<style type="text/css"> 
input { 
margin-right: 60px; 
} 
</style> 
< /head> 
< body> 
<p> 
让我猜猜你心中的牌<br /> 
首先从列表中选择一张你心目中的牌,并且记住它,然后选择它所在的列,点击三次我将会猜出你心目中的牌。<br /> 
来试试吧,我懂你的!<br /> 
如果遇到牌无法显示,或者显示不全,请刷新.如果你的浏览器不支持HTML5,请更换浏览器,例如chrome,火狐等 
</p> 
<canvas width="700" height="400" id="canvas">你的浏览器不支持HTML5,请更换浏览器,例如chrome,火狐等</canvas> 
<br /> 
<input type="button" value="第一列" /> 
<input type="button" value="第二列" /> 
<input type="button" value="第三列" /> 
<input type="button" value="再来一次" /> 
< /body> 
< /html>
Javascript 相关文章推荐
Javascript表达式中连续的 &amp;&amp; 和 || 之赋值区别
Oct 17 Javascript
JavaScript节点及列表操作实例小结
Aug 05 Javascript
js如何判断访问是来自搜索引擎(蜘蛛人)还是直接访问
Sep 14 Javascript
基于zepto的移动端轻量级日期插件--date_picker
Mar 04 Javascript
jQuery height()、innerHeight()、outerHeight()函数的区别详解
May 23 Javascript
jQuery Ajax使用FormData上传文件和其他数据后端web.py获取
Jun 11 jQuery
利用Node.js检测端口是否被占用的方法
Dec 07 Javascript
vue+axios+element ui 实现全局loading加载示例
Sep 11 Javascript
js图数据结构处理 迪杰斯特拉算法代码实例
Sep 11 Javascript
vue-socket.io跨域问题有效解决方法
Feb 11 Javascript
JS 基本概念详细介绍
Oct 16 Javascript
JavaScript实例 ODO List分析
Jan 22 Javascript
js中如何把字符串转化为对象、数组示例代码
Jul 17 #Javascript
js函数setTimeout延迟执行的简单介绍
Jul 17 #Javascript
JavaScript地图拖动功能SpryMap的简单实现
Jul 17 #Javascript
js导出格式化的excel 实例方法
Jul 17 #Javascript
js检查页面上有无重复id的实现代码
Jul 17 #Javascript
基于pthread_create,readlink,getpid等函数的学习与总结
Jul 17 #Javascript
jcrop基本参数一览
Jul 16 #Javascript
You might like
一段php加密解密的代码
2007/07/16 PHP
PHP面向对象概念
2011/11/06 PHP
使用PHP下载CSS文件中的图片的代码
2013/09/24 PHP
PHP框架Laravel学习心得体会
2015/10/28 PHP
Prototype使用指南之range.js
2007/01/10 Javascript
js 数组克隆方法 小结
2010/03/20 Javascript
利用js实现遮罩以及弹出可移动登录窗口
2013/07/08 Javascript
js中取得变量绝对值的方法
2015/01/03 Javascript
IE9+已经不对document.createElement向下兼容的解决方法
2015/09/14 Javascript
跟我学习javascript的var预解析与函数声明提升
2015/11/16 Javascript
JS从一组数据中找到指定的单条数据的方法
2016/06/02 Javascript
浅析js的模块化编写 require.js
2016/12/07 Javascript
vue如何实现observer和watcher源码解析
2017/03/09 Javascript
深入理解Commonjs规范及Node模块实现
2017/05/17 Javascript
使用Dropzone.js上传的示例代码
2017/10/10 Javascript
使用vue-cli4.0快速搭建一个项目的方法步骤
2019/12/04 Javascript
彻底搞懂并解决vue-cli4中图片显示的问题实现
2020/08/31 Javascript
基于ID3决策树算法的实现(Python版)
2017/05/31 Python
python使用logging模块发送邮件代码示例
2018/01/18 Python
Python网页正文转换语音文件的操作方法
2018/12/09 Python
​如何愉快地迁移到 Python 3
2019/04/28 Python
Python同时迭代多个序列的方法
2020/07/28 Python
Django如何实现防止XSS攻击
2020/10/13 Python
sklearn中的交叉验证的实现(Cross-Validation)
2021/02/22 Python
世界上最大的巴士旅游观光公司:Big Bus Tours
2016/10/20 全球购物
Holiday Inn中国官网:IHG旗下假日酒店预订
2018/04/08 全球购物
.NET方向面试题
2014/11/20 面试题
盛大二次面试题
2016/11/18 面试题
C++程序员求职信
2014/05/07 职场文书
党的作风建设心得体会
2014/10/22 职场文书
迟到检讨书范文
2015/01/27 职场文书
圣诞节开幕词
2015/01/29 职场文书
资料员岗位职责范本
2015/04/13 职场文书
导游词之贵州织金洞
2019/10/12 职场文书
Python爬虫基础之简单说一下scrapy的框架结构
2021/06/26 Python
Android中View.post和Handler.post的关系
2022/06/05 Java/Android