学习javascript估摸着有半个多月了,好歹自己有过编程基础,学的还算轻松,不过js里的面向对象是真的打脑壳,但都但不懂,和我以前学过的c#简直相差太远
今天写了个随机生成斗地主玩家手牌的代码,自己还蛮满意的,一溜叽滚下床,戳开电脑来分享一手
虽然这种东西根本没啥用,哈哈
卡牌列表数组元素类型:
[1, "黑桃", 11, "K"]
每一张卡牌为一个数组,有4个元素,0号元素代表当前花色大小,2号元素代表当前卡片数值大小,1号和3号都是字符串,用来表示卡牌表面信息
比较大小分为两种情况,卡片数值不同和卡片数值相同
卡片数值不同情况直接比较卡片数值大小来排序,卡片数值相同就需要比较花色大小来排序
难点就在于将手牌进行排序,有了思路以后就好做了,直接贴上代码!
//创建卡牌 function CreatePoker() { let color = [[1, "黑桃",], [2, "红桃"], [3, "梅花"], [4, "方块"]]; let number = [[1, "3"], [2, "4"], [3, "5"], [4, "6"], [5, "7"], [6, "8"], [7, "9"], [8, "10"], [9, "J"], [10, "Q"], [11, "K"], [12, "A"], [13, "2"]]; //创建卡牌数组,每种颜色对应一种数值 let pokerList = []; for (let i = 0; i !== color.length; i++) { for (let j = 0; j !== number.length; j++) { pokerList.push([...color[i], ...number[j]]); } } //添加大小王 pokerList.push(["", "", 14, "小 王"]); pokerList.push(["", "", 15, "大 王"]); //将卡牌数组打乱,随机返回-1或者是1就可以乱排序 pokerList.sort(() => { return Math.random() > 0.5 ? -1 : 1; }); return pokerList;//最后将得到的卡牌数组返回 } function GivePoker(pokerList) { //直接从乱序数组中剔除得到17项,然后排序 let sortArr = SortPoker(pokerList.splice(0, 17)); //格式化输出 let str = ""; for (let poker of sortArr) { str += poker[1] + poker[3] + " "; } return str; } //排序数组 function SortPoker(pokerList) { pokerList.sort((poker1, poker2) => { //卡牌数值相同比较花色 if (poker1[2] === poker2[2]) { return poker1[0] - poker2[0]; } //卡牌数值不同比较数值 return poker1[2] - poker2[2]; }); return pokerList; } let pokerList = CreatePoker(); let player1Poker = GivePoker(pokerList); let player2Poker = GivePoker(pokerList); let player3Poker = GivePoker(pokerList); let lastPoker = GivePoker(pokerList); console.log("玩家1:" + player1Poker); console.log("玩家2:" + player2Poker); console.log("玩家3:" + player3Poker); console.log("底 牌:" + lastPoker);
下午的时候写的代码有足足80行,回家后又思考优化后只有40行了,个人感觉良好,哈哈,膨胀了膨胀了,睡觉!明天继续努力学习!