前几天,朋友找我一起做个扑克牌顺子的游戏, 由于忙于工作一直没时间看, 今天空下来研究一下;
顺带介绍下那位朋友, 萝卜爱吃青菜 有兴趣的朋友可以去他的博客逛逛, 里面有好多他的实用分享;
下面进入正题:
描述:从扑克牌中随机抽5 张牌,判断是不是一个顺子,即这5 张牌是不是连续的。2-10 为数字本身,A 为1,J 为11,Q 为12,K 为13,而大小王可以看成任意数字
xxxxxxxxxx
function pokerGame() {
let pokerArr = []; // 存放54张牌
let testArr = []; // 存放随机抽取的5张牌
for(let i = 1; i < 14; i++) {
for(let j = 0; j < 4; j++) {
pokerArr.push(i) // 添加52张牌 进牌组
}
};
// 添加大小鬼牌
pokerArr.push('x');
pokerArr.push('X');
// 随机抽取5张牌 进行测试
for(var i = 0; i < 5; i++) {
let length = pokerArr.length;
// 为了还原真实性, 每次抽取都会从原有牌组剩余部分 进行重新抽取
let randomNum = Math.floor(Math.random()*length);
let arr = pokerArr.splice(randomNum, 1)
testArr = testArr.concat(arr)
};
// 进行测试
isStraight(testArr)
}
function isStraight(testArr) {
let arrFive = [testArr]; // 对传入参数进行赋值,
let arr = []; // 用于存放 除大小鬼之外的数字牌
let ghost = 0; // 记录 大小鬼牌的张数
let bool = true; // 判定是否为顺子
// 记录鬼牌出现次数, 并在 arr 中剔除鬼牌
arrFive.forEach( item => {
isNaN(item) ? ghost++ : arr.push(item)
} )
// 对剩余牌 进行排序
arr.sort( (a, b) => a - b )
for(var i = arr.length-1; i > 0; i--) {
// 当前牌和下一张牌的差值
let val = arr[i] - arr[i-1];
switch(val) {
case 1:
break;
case 2:
case 3:
// 因为鬼牌可以变成任意一张牌, 所以当差值为 2 和 3 时, 可以使用鬼牌进行替换, 鬼牌使用 这里要重新记录鬼牌是剩余张数
ghost -= (val-1)
break;
default:
// 如果差值为 0 则说明存在重复的牌,或者
// 如果差值大于 3 即使当前测试牌组 两张鬼牌都存在,也不能满足顺子要求, 直接判定 测试牌组不为顺子
return bool = false
}
if(ghost < 0) {
// 在循环内, 如果 ghost 小于0 说明 鬼牌次数使用完毕,仍不满足要求, 判定 测试牌组不为顺子
return bool = false
}
}
if(bool) {
console.log('「^^^^^^^^^^^^^^^^^^^^^^^^^^^^')
console.log('测试牌组', arrFive)
console.log(arr)
console.log('____________________________」')
}
}
// 进入循环测试
for(var i = 0; i < 30; i++) {
console.log('测试执行:', i+1)
pokerGame();
}