牛客网在线编程专题《剑指offer-面试题44》扑克牌顺子

我的个人微信公众号:Microstrong

微信公众号ID:MicrostrongAI

微信公众号介绍:Microstrong(小强)同学主要研究机器学习、深度学习、计算机视觉、智能对话系统相关内容,分享在学习过程中的读书笔记!期待您的关注,欢迎一起学习交流进步!

知乎主页:https://www.zhihu.com/people/MicrostrongAI/activities

Github:https://github.com/Microstrong0305

个人博客:https://blog.csdn.net/program_developer

 题目链接:

https://www.nowcoder.com/practice/762836f4d43d43ca9deb273b3de8e1f4

题目描述:

解题思路:

(1)暴力解法,考虑每种情况

已经AC的代码:

class Solution:
    def IsContinuous(self, numbers):
        if numbers is None or len(numbers) < 5:
            return False

        new_numbers = sorted(numbers)
        count_zero = new_numbers.count(0)

        if count_zero == 0:
            if self.isContinueNum(new_numbers):
                return True
            else:
                return False
        if count_zero == 1:
            # 从第1位到最后1位是连续子序列
            if self.isContinueNum(new_numbers[1:]):
                return True
            # 中间有缺失1个数字
            elif self.fillOne(new_numbers[1:]):
                return True
            else:
                return False
        if count_zero == 2:
            # 从第2位到最后1位是连续子序列
            if self.isContinueNum(new_numbers[2:]):
                return True
            # 中间有缺失1个数字
            elif self.fillOne(new_numbers[2:]):
                return True
            # 中间缺失2个数字
            elif self.fillTwo(new_numbers[2:]):
                return True
            else:
                return False

        if count_zero == 3:
            # 从第3位到最后1位是连续子序列
            if self.isContinueNum(new_numbers[3:]):
                return True
            # 中间有缺失1个数字
            elif self.fillOne(new_numbers[3:]):
                return True
            # 中间缺失2个数字
            elif self.fillTwo(new_numbers[3:]):
                return True
            # 中间缺失3个数字
            elif self.fillThree(new_numbers[3:]):
                return True
            else:
                return False
        if count_zero >= 3:
            return True

    # 判断一个序列是否是连续的数字
    def isContinueNum(self, numbers):
        count = 0
        for i in range(1, len(numbers), 1):
            if numbers[i] - numbers[i - 1] == 1:
                count += 1

        if count == len(numbers) - 1:
            return True
        else:
            return False

    # 填充一个数字能否满足连续序列
    def fillOne(self, numbers):
        for i in range(1, len(numbers), 1):
            if numbers[i] - numbers[i - 1] != 1:
                numbers.insert(i, numbers[i - 1] + 1)
                break

        if self.isContinueNum(numbers):
            return True
        else:
            return False

    # 填充2个数字能否满足连续序列
    def fillTwo(self, numbers):
        count = 0
        for i in range(1, len(numbers) + 2, 1):
            if numbers[i] - numbers[i - 1] != 1:
                if count < 2:
                    numbers.insert(i, numbers[i - 1] + 1)
                    count += 1
                else:
                    break

        if self.isContinueNum(numbers):
            return True
        else:
            return False

    # 填充3个数字能否满足连续序列
    def fillThree(self, numbers):
        count = 0
        for i in range(1, len(numbers) + 3, 1):
            if numbers[i] - numbers[i - 1] != 1:
                if count < 3:
                    numbers.insert(i, numbers[i - 1] + 1)
                    count += 1
                else:
                    break

        if self.isContinueNum(numbers):
            return True
        else:
            return False

(2)统计缺失的数字个数是否等于大小王的个数

已经AC的代码:

# -*- coding:utf-8 -*-
class Solution:
    def IsContinuous(self, numbers):
        # write code here
        if numbers == None or len(numbers) < 5:
            return False

        numbers.sort()

        zero_count = numbers.count(0)

        if zero_count >= 4:
            return True

        if zero_count > 0:
            numbers = list(filter(lambda x: x != 0, numbers))

        absent_list = self.IsSeries(numbers)

        if zero_count == len(absent_list):
            return True
        else:
            return False

    def IsSeries(self, array):
        absent_list = []
        tempList = list(range(array[0], array[-1] + 1))
        for index, item in enumerate(tempList):
            if item not in array:
                absent_list.append(item)
        return absent_list

(3)《剑指offer》中解题方法

已经AC的代码:

# -*- coding:utf-8 -*-
class Solution:
    def IsContinuous(self, numbers):
        # write code here
        if not numbers or len(numbers) < 1:
            return False

        numbers.sort()

        # 统计数组中0的个数
        numberOfZero = numbers.count(0)
        numberOfGap = 0

        # 统计数组中的间隔数目
        small = numberOfZero
        big = small + 1
        while big < len(numbers):
            # 两个数相等,有对子,不可能是顺子
            if numbers[small] == numbers[big]:
                return False
            numberOfGap += (numbers[big] - numbers[small] - 1)
            small = big
            big += 1

        return False if numberOfGap > numberOfZero else True

 

已标记关键词 清除标记
相关推荐
第1章 面试的流程   1.1 面试官谈面试   1.2 面试的三种形式   1.2.1 电话面试   1.2.2 共享桌面远程面试   1.2.3 现场面试   1.3 面试的三个环节   1.3.1 行为面试环节   应聘者的项目经验   应聘者掌握的技能   回答"为什么跳槽"   1.3.2 技术面试环节   扎实的基础知识   高质量的代码   清晰的思路   优化效率的能力   优秀的综合能力   1.3.3 应聘者提问环节   1.4 本章小结   第2章 面试需要的基础知识   2.1 面试官谈基础知识   2.2 编程语言   2.2.1 C++   面试题1:赋值运算符函数   经典的解法,适用于初级程序员   考虑异常安全性的解法,高级程序员必备   2.2.2 C#   面试题2:实现Singleton模式   不好的解法一:只适用于单线程   不好的解法二:可用于多线程但效率不高   可行的解法:同步锁前后两次判断   推荐的解法一:利用静态构造函数   推荐的解法二:按需创建实例   解法比较   2.3 数据结构   2.3.1 数组   面试题3:二维数组中的查找   2.3.2 字符串   面试题4:替换空格   O(n2)的解法,不足以拿到Offer   O(n)的解法,搞定Offer就靠它   2.3.3 链表   面试题5:从尾到头打印链表   2.3.4 树   面试题6:重建二叉树   2.3.5 栈和队列   面试题7:用两个栈实现队列   2.4 算法和数据操作   2.4.1 查找和排序   面试题8:旋转数组的最小数字   2.4.2 递归和循环   面试题9:斐波那契数列   效率很低的解法,面试官不会喜欢   面试官期待的实用解法   O(logn)但不够实用的解法   解法比较   2.4.3 位运算   面试题10:二进制中1的个数   可能引起死循环的解法   常规解法   能给面试官带来惊喜的解法   2.5 本章小结   第3章 高质量的代码   3.1 面试官谈代码质量   3.2 代码的规范性   3.3 代码的完整性   从3方面确保代码的完整性   3种错误处理的方法   面试题11:数值的整数次方   自以为题目简单的解法   全面但不够高效的解法,离Offer已经很近了   全面又高效的解法,确保能拿到Offer   面试题12:打印1到最大的n位数   跳进面试官陷阱   在字符串上模拟数字加法   把问题转换成数字排列   面试题13:在O(1)时间删除链表结点   面试题14:调整数组顺序使奇数位于偶数前面   只完成基本功能的解法,仅适用于初级程序员   考虑可扩展性的解法,能秒杀Offer   3.4 代码的鲁棒性   面试题15:链表中倒数   第k个结点   面试题16:反转链表   面试题17:合并两个排序的链表   面试题18:树的子结构   3.5 本章小结   第4章 解决面试题的思路   4.1 面试官谈面试思路   面试题19:二叉树的镜像   4.2 画图让抽象问题形象化   面试题20:顺时针打印矩阵   4.3 举例让抽象问题具体化   面试题21:包含min函数的栈   面试题22:栈的压入、弹出序列   面试题23:从上往下打印二叉树   面试题24:二叉搜索树的后序遍历序列   面试题25:二叉树中和为某一值的路径   4.4 分解让复杂问题简单化   面试题26:复杂链表的复制   面试题27:二叉搜索树与双向链表   面试题28:字符串的排列   4.5 本章小结   第5章 优化时间和空间效率   5.1 面试官谈效率   5.2 时间效率   面试题29:数组中出现次数超过一半的数字   基于Partition函数的O(n)算法   利用数组特点的O(n)算法   解法比较   面试题30:最小的k个数   O(n)的算法,只当可以修改输入数组时可用   O(nlogk)的算法,适合处理海量数据   解法比较   面试题31:连续子数组的最大和   举例分析数组的规律   应用动态规划法   面试题32:从1到n整数中1出现的次数   不考虑效率的解法,想拿Offer有点难   明显提高效率的解法,让面试官耳目一新   面试题33:把数组排成最小的数   5.3 时间效率与空间效率的平衡   面试题34:丑数   逐个判断整数是不是丑数的解法   创建数组保存已经找到的丑数的解法   面试题35:   第一个只出现一次的字符   面试题36:数组中的逆序对   面试题37:两个链表的   第一个公共结点   5.4 本章小结   第6章 面试中的各项能力   6.1 面试官谈能力   6.2 沟通能力和学习能力   沟通能力   学习能力   善于学习、沟通的人也善于提问   6.3 知识迁移能力   面试题38:数字在排序数组中出现的次数   面试题39:二叉树的深度   重复遍历结点的解法,不足以打动面试官   只遍历结点一次的解法,正是面试官喜欢的   面试题40:数组中只出现一次的数字   面试题41:和为s的两个数字VS和为s的连续正数序列   面试题42:翻转单词顺序 VS左旋转字符串   6.4 抽象建模能力   面试题43:n个骰子的点数   基于递归求骰子点数,时间效率不够高   基于循环求骰子点数,时间性能好   面试题44:扑克牌顺子   面试题45:圆圈中最后剩下的数字   经典的解法,用循环链表模拟圆圈   创新的解法,拿到Offer不在话下   6.5 发散思维能力   面试题46:求1+2+…+n   利用构造函数求解   利用虚函数求解   利用函数指针求解   利用模板类型求解   面试题47:不用加减乘除做加法   面试题48:不能被继承的类   常规的解法:把构造函数设为私有函数   新奇的解法:利用虚拟继承   6.6 本章小结   第7章 两个面试案例   7.1 案例一:(面试题49)把字符串转换成整数   7.2 案例二:(面试题50)树中两个结点的最低公共祖先 [1] 第8章 英文版新增面试题   8.1 数组   面试题51:数组中重复的数字   面试题52:构建乘积数组   8.2 字符串   面试题53:正则表达式匹配   面试题54:表示数值的字符串   面试题55:字符流中   第一个不重复的字符   8.3 链表   面试题56:链表中环的入口结点   面试题57:删除链表中重复的结点   8.4 树   面试题58:二叉树的下一个结点   面试题59:对称的二叉树   面试题60:把二叉树打印成多行   面试题61:按之字形顺序打印二叉树   面试题62:序列化二叉树   面试题63:二叉搜索树的   第k个结点   面试题64:数据流中的中位数   8.5 栈和队列   面试题65:滑动窗口的最大值   8.6 回溯法   面试题66:矩阵中的路径   面试题67:机器人的运动范围
程序员的必经之路! 【限时优惠】 现在下单,还享四重好礼: 1、教学课件免费下载 2、课程案例代码免费下载 3、专属VIP学员群免费答疑 4、下单还送800元编程大礼包 【超实用课程内容】  根据《2019-2020年中国开发者调查报告》显示,超83%的开发者都在使用MySQL数据库。使用量大同时,掌握MySQL早已是运维、DBA的必备技能,甚至部分IT开发岗位也要求对数据库使用和原理有深入的了解和掌握。 学习编程,你可能会犹豫选择 C++ 还是 Java;入门数据科学,你可能会纠结于选择 Python 还是 R;但无论如何, MySQL 都是 IT 从业人员不可或缺的技能!   套餐中一共包含2门MySQL数据库必学的核心课程(共98课时)   课程1:《MySQL数据库从入门到实战应用》   课程2:《高性能MySQL实战课》   【哪些人适合学习这门课程?】  1)平时只接触了语言基础,并未学习任何数据库知识的人;  2)对MySQL掌握程度薄弱的人,课程可以让你更好发挥MySQL最佳性能; 3)想修炼更好的MySQL内功,工作中遇到高并发场景可以游刃有余; 4)被面试官打破沙锅问到底的问题问到怀疑人生的应聘者。 【课程主要讲哪些内容?】 课程一:《MySQL数据库从入门到实战应用》 主要从基础篇,SQL语言篇、MySQL进阶篇三个角度展开讲解,帮助大家更加高效的管理MySQL数据库。 课程二:《高性能MySQL实战课》主要从高可用篇、MySQL8.0新特性篇,性能优化篇,面试篇四个角度展开讲解,帮助大家发挥MySQL的最佳性能的优化方法,掌握如何处理海量业务数据和高并发请求 【你能收获到什么?】  1.基础再提高,针对MySQL核心知识点学透,用对; 2.能力再提高,日常工作中的代码换新貌,不怕问题; 3.面试再加分,巴不得面试官打破沙锅问到底,竞争力MAX。 【课程如何观看?】  1、登录CSDN学院 APP 在我的课程中进行学习; 2、移动端:CSDN 学院APP(注意不是CSDN APP哦)  本课程为录播课,课程永久有效观看时长 【资料开放】 课件、课程案例代码完全开放给你,你可以根据所学知识,自行修改、优化。  下载方式:电脑登录课程观看页面,点击右侧课件,可进行课程资料的打包下载。
©️2020 CSDN 皮肤主题: 编程工作室 设计师:CSDN官方博客 返回首页