剑指offer系列——45.扑克牌顺子

Q:LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是54张^_^)...他随机从中抽出了5张牌,想测测自己的手气,看看能不能抽到顺子,如果抽到的话,他决定去买体育彩票,嘿嘿!!“红心A,黑桃3,小王,大王,方片5”,“Oh My God!”不是顺子.....LL不高兴了,他想了想,决定大\小 王可以看成任何数字,并且A看作1,J为11,Q为12,K为13。上面的5张牌就可以变成“1,2,3,4,5”(大小王分别看作2和4),“So Lucky!”。LL决定去买体育彩票啦。 现在,要求你使用这幅牌模拟上面的过程,然后告诉我们LL的运气如何, 如果牌能组成顺子就输出true,否则就输出false。为了方便起见,你可以认为大小王是0。
T:
1.满足两个条件:除0以外没有数字重复;除0外最大值和最小值之间误差小于5

    bool IsContinuous(vector<int> numbers) {
        if (numbers.empty() || numbers.size() != 5)
            return false;
        int maxnum = *max_element(numbers.begin(), numbers.end());
        int minnum = *min_element(numbers.begin(), numbers.end());
        if (maxnum > 14 || minnum < 0)
            return false;
        int hash[15] = {0};
        for (int i = 0; i < numbers.size(); i++)
            hash[numbers[i]]++;
        if (hash[0] == 5)
            return false;
        vector<int> temp;
        for (int i = 1; i < 15; i++) {
            if (hash[i] > 1)
                return false;
            else if (hash[i] == 1)
                temp.push_back(i);
        }
        minnum = *min_element(temp.begin(), temp.end());
        return maxnum - minnum < 5;
    }

P.S.初始化hash全为0,否则会自动往里随机填值。初始化数组为0的方法为 array = {0} 或 memset(array, 0, ARRAY_SIZE_MAX);
这里介绍一下两个函数:
max_element:include from algorithm,返回值为最大值的位置,通过*max_element(vector)来获取最大值;
min_element:include from algorithm,返回值为最小值的位置,通过*min_element(vector)来获取最小值;

原文地址:https://www.cnblogs.com/xym4869/p/12343110.html

时间: 2024-08-04 14:52:20

剑指offer系列——45.扑克牌顺子的相关文章

剑指Offer系列之题11~题15

目录 11.矩形覆盖 12.二进制中1的个数 13. 数值的整数次方 14.调整数组顺序使奇数位于偶数前面 15.链表中倒数第k个结点 11.矩形覆盖 我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形.请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法? 比如n=3时,2*3的矩形块有3种覆盖方法: 斐波那契数列的应用 第一次竖着放一块类比为走一步,第一次横着放两块类比为走两步 代码与上面的斐波那契数列类题目类似,此处不再赘述:剑指Offer系列之题6~题10. 12.

剑指offer系列10:合并两个排序的链表

我拿到这个题的时候举的例子是链表1:1.3.5.7和链表2:2.4.6.8.我的思路是以:1为基础,将表2的每个结点插入表1.也就是说我一次性是要给新建立的链表中加入两个元素,分别是两个原始链表的头结点.这个思路我做了半天头脑一片混乱,中间指针实在不知道怎么弄了.于是我去睡了一觉,哈哈,我大概是这个世界上最会逃避的人了…… 看了答案使用了递归的方法,其实我做的时候我有想到要用递归,但是没用的原因是我一般写代码不喜欢用递归,原因有两个,一个是递归容易死循环,一个是递归的复杂度太高.但这道题真的太适

剑指offer系列4:斐波那契数列

剑指offer第九题,这个题很古老了.第一个想到的肯定是递归,很简单. 1 #include<iostream> 2 #include<vector> 3 using namespace std; 4 class Solution { 5 public: 6 int Fibonacci(int n) { 7 if (n == 0) 8 { 9 return 0; 10 } 11 if (n==1||n==2) 12 { 13 return 1; 14 } 15 else 16 {

剑指offer系列47:堆成的二叉树

这个题的主要思路是: 用二叉树的左子树的右子树和右子树的左子树比较,再用左子树的左子树和右子树的右子树比较.(好像有点绕,但其实就是堆成的思想) 剑指offer的说法是用数的前序遍历的两个方法,前序遍历应该是:根->左->右.但是我们用另一种前序遍历:根->右->左.如果这两个序列一样就判断它是对称的. 这两个方法在实现上其实是一样的. 1 class Solution { 2 public: 3 bool isSymmetrical(TreeNode* pRoot) 4 { 5

剑指offer系列源码-扑克牌顺子

题目1355:扑克牌顺子 时间限制:2 秒内存限制:32 兆特殊判题:否提交:1415解决:398 题目描述: LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是54张^_^)...他随机从中抽出了5张牌,想测测自己的手气,看看能不能抽到顺子,如果抽到的话,他决定去买体育彩票,嘿嘿!!"红心A,黑桃3,小王,大王,方片5","Oh My God!"不是顺子.....LL不高兴了,他想了想,决定大\小 王可以看成任何数字,并且A

剑指offer系列——48.不用加减乘除做加法

Q:写一个函数,求两个整数之和,要求在函数体内不得使用+.-.*./四则运算符号. T: 1.使用进制. 两个数异或:相当于每一位相加,而不考虑进位: 两个数相与,并左移一位:相当于求得进位: 将上述两步的结果相加 首先看十进制是如何做的: 5+7=12,三步走 第一步:相加各位的值,不算进位,得到2. 第二步:计算进位值,得到10. 如果这一步的进位值为0,那么第一步得到的值就是最终结果. 第三步:重复上述两步,只是相加的值变成上述两步的得到的结果2和10,得到12. 同样我们可以用三步走的方

剑指offer系列35:扑克牌顺子

把大小王当做0.然后对整个序列排序.排序后计算大小王的数目和需要大小王填的坑的数目.如果大小王数目大于等于要填的坑的数目就返回真,否则返回假. 1 class Solution { 2 public: 3 bool IsContinuous(vector<int> numbers) { 4 if (numbers.empty()) 5 return false; 6 sort(numbers.begin(), numbers.end()); 7 //count:需要填的坑的数目,king:大小

剑指offer系列26--正则表达式匹配

[题目]请实现一个函数用来匹配包括’.’和’*‘的正则表达式.模式中的字符’.’表示任意一个字符,而’‘表示它前面的字符可以出现任意次(包含0次). 在本题中,匹配是指字符串的所有字符匹配整个模式.例如,字符串”aaa”与模式”a.a”和”abaca”匹配,但是与”aa.a”和”aba”均不匹配 1 package com.exe6.offer; 2 /** 3 * [题目]请实现一个函数用来匹配包括’.’和’*‘的正则表达式.模式中的字符’.’表示任意一个字符, 4 * 而’‘表示它前面的字符

剑指offer系列27--表示数值的字符串

[题目]请实现一个函数用来判断字符串是否表示数值(包括整数和小数). 例如,字符串”+100”,”5e2”,”-123”,”3.1416”和”-1E-16”都表示数值. 但是”12e”,”1a3.14”,”1.2.3”,”+-5”和”12e+4.3”都不是. 1 package com.exe6.offer; 2 /**[题目] 3 * 请实现一个函数用来判断字符串是否表示数值(包括整数和小数). 4 * 例如,字符串”+100”,”5e2”,”-123”,”3.1416”和”-1E-16”都表