zoukankan      html  css  js  c++  java
  • 扑克牌顺子

    扑克牌顺子

    题目描述

    从扑克牌中随机抽取5张牌, 判断是不是一个顺子, 即这5张牌是不是连续的. 2~10为数字本身, A为1, J为11, Q为12, K为13, 大小王看成是任意数字并在数组中用0表示

    新学一招, bitmap排序, 传输门 ----> bitmap对海量无重复的整数排序

    class Solution {
    public:
        bool IsContinuous( vector<int> numbers ) {
            if (5 != numbers.size()) 
                return false;
            int max = -1;
            int min = 14;
            
            int flag = 0;
            
            for (int i = 0; i < 5; i++) {
                int temp = numbers[i];
                if ((0 > temp) || 13 < temp)    return false;
                // 为0则继续遍历下一个数字
                if (0 == temp)    continue;
                // 有重复数字, 及该位已经置1了
                if (1 == ((flag >> temp) & 1))    return false;
                // 标记出现数字
                flag |= (1 << temp);
                if (temp > max)        max = temp;
                if (temp < min)        min = temp;
                if (max - min >= 5)    return false;
            }
            return true;
        }
    };
    

    哈希表法

    class Solution {
    public:
        bool IsContinuous( vector<int> numbers ) {
            if(numbers.empty()) {
                return false;
            }
            vector<int> vt;
            vt.resize(14);
            int len = numbers.size();
            int max = -1;
            int min = 14;
            for (int i = 0; i < len; i++) {
                vt[numbers[i]]++;
                if(0 == numbers[i]) {
                    continue;
                }
                if (vt[numbers[i]] > 1) {
                    return false;
                }
                if (numbers[i] > max) {
                    max = numbers[i];
                }
                if (numbers[i] < min) {
                    min = numbers[i];
                }
            }
            if (max - min < 5) {
                return true;
            }
            return false;
        }
    };
    

    判断条件比下面那个简化多了, 使用一个变量记录排好序后数组相邻两个元素的差值

    class Solution {
    public:
        bool IsContinuous( vector<int> numbers ) {
            if (4 >= numbers.size()) {
                return false;
            }
            
            sort(numbers.begin(), numbers.end());
            
            int numbersOfZero = 0;
            int numbersOfGape = 0;
            int i = 0;
            while (i < (numbers.size() - 1)) {
                if (0 == numbers[i]) {
                    numbersOfZero++;
                    i++;
                    continue;
                }
                
                if (numbers[i] == numbers[i+1]) {
                    return false;
                }
                numbersOfGape = numbersOfGape + numbers[i+1] - numbers[i] - 1;
                i++;
            }
            
            return (numbersOfGape > numbersOfZero ? false : true);
        }
    };
    

    有点作弊了, 使用了排序函数, 最后的输出真是层层围堵, 各种判断

    class Solution {
    public:
        bool IsContinuous( vector<int> numbers ) {
            if (4 >= numbers.size()) {
                return false;
            }
            
            sort(numbers.begin(), numbers.end());
            
            int numberOfZero = 0;
            int i = 0;
            while (i < (numbers.size() - 1)) {
                if (0 == numbers[i]) {
                    numberOfZero++;
                    i++;
                    continue;
                }
                
                if (numbers[i] == numbers[i+1]) {
                    return false;
                }
                else if (1 == numbers[i+1] - numbers[i]) {
                    i++;
                }
                else if ((numberOfZero > 0) && (numbers[i+1] - numbers[i] <= numberOfZero + 1)) {
                    numberOfZero = numberOfZero - (numbers[i+1] - numbers[i]) + 1;
                    i++;
                }
                else {
                    return false;
                }
            }
            
            return true;
        }
    };
    
  • 相关阅读:
    子网划分详解
    USACO range
    USACO shopping
    USACO fence
    USACO Spinning Wheels
    USACO butter
    USACO msquare
    USACO Feed Ratios
    USACO Stringsobits
    USACO Factorials
  • 原文地址:https://www.cnblogs.com/hesper/p/10527412.html
Copyright © 2011-2022 走看看