0
点赞
收藏
分享

微信扫一扫

面试题 扑克牌解法

芒果六斤半 2022-04-20 阅读 20
面试html

从扑克牌中随机抽5张牌,判断是不是一个顺子, 即这5张牌是不是连续的   2~10为数字本身, A为1。 J为11、Q为12、 为13。小王可以看成任意数字

function getPoker() {
            var arr = ['A', 2, 3, 4, 5, 6, 7, 8, 9, 'J', 'Q', 'K']
            arr = [...arr, ...arr, ...arr, ...arr, '大王', '小王']
            var newArr = []
            for (var i = 0; i < 5; i++) {
                var random = Math.floor(Math.random() * arr.length)
                newArr.push(arr[random])
                arr.splice(random, 1)
            }
            return newArr
        }
        function temp4(arr) {
            console.log('你输入的是', arr);
            // 空数组用来存放特殊字符,做转换
            var arr1 = []
            // 大小王的数量
            var num = 0;
            // 遍历是否重复
            for (var i in arr) {
                if (arr.lastIndexOf(arr[i]) + '' !== i) {
                    return false
                }
            }
            // 两个数组分开数字和特殊字符
            for (var i = 0; i < arr.length; i++) {
                if (typeof arr[i] === 'string') {
                    arr1.push(arr[i])
                    arr.splice(i, 1)
                    i--;
                }
            }
            // 判断数组的大小王有多少张,并且把特殊字符转为数字
            for (var i in arr1) {
                if (arr1[i].length > 1) {
                    arr1[i] = 0;
                    num++;
                }
                arr1[i] === 'A' && (arr1[i] = 1)
                arr1[i] === 'J' && (arr1[i] = 11)
                arr1[i] === 'Q' && (arr1[i] = 12)
                arr1[i] === 'K' && (arr1[i] = 13)
            }
            // 合并两个数组
            arr = [...arr, ...arr1];
            // 进行冒泡排序
            arr.sort((a, b) => a - b)
            // 如果最大减去最小(大小王除外)为4,并且不重复,则必是顺子
            if (arr[4] - arr[num] <= 4) {
                return true
            } else {
                return false
            }
        }
        console.log(temp4(getPoker()));
举报

相关推荐

0 条评论