• test


    前几天,朋友找我一起做个扑克牌顺子的游戏, 由于忙于工作一直没时间看, 今天空下来研究一下;

    顺带介绍下那位朋友, 萝卜爱吃青菜 有兴趣的朋友可以去他的博客逛逛, 里面有好多他的实用分享;

    下面进入正题:

    描述:从扑克牌中随机抽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();
    }
     
  • 相关阅读:
    【LeetCode】链表 linked list(共34题)
    Construct Binary Tree from Preorder and Inorder Traversal<leetcode>
    Triangle <leetcode>
    Jump Game <leetcode>
    C++学习笔记 <const限定词>
    Search for a Range <leetcode>
    Subsets <leetcode>
    各种排序算法总结
    Unique Paths II <leetcode>
    C++学习笔记 <hash_map> <散列映射>
  • 原文地址:https://www.cnblogs.com/vant850/p/11242733.html
Copyright © 2020-2023  润新知