面试题61. 扑克牌中的顺子

news2024/9/19 10:37:38

晚上做了道题,写完看了大佬的题解发现自己很蠢,思维不够光想着模拟了,来回考虑细节磕磕绊绊写完这么一道题。虽然也是写出来了,复杂度都是ok的,不过代码长,处理细节麻烦。

记录一下这道题

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

 拿到这个题思路还是不难的

 说了大小王默认是0,可以当做任何数,题里没说给的数组是有序的

 因此我们先要排序,然后计算一下自己有多少张王,最多也就两张。

 然后去遍历数组:

  1. 如果有对子,肯定不能成顺子直接返回错误
  2. 看顺子的话,如果相邻的差1,说明这两张可以构成小顺子,就需要看后面的牌
  3. 如果不差1,说明就需要用大小王去替换了(我们默认有王牌的,前面统计过有几张,可能是0,1,2),怎么替换呢,就需要算一下不是顺子这两个之间如果要构成顺子需要几张王牌,用我们当前有的王牌去减对应所需要的牌数
  4. 减到后面,如果发现王牌小于0了,说明不够替换了,就直接返回false就行
  5. 最终的返回值就看王牌数是否>=0了,>=0了说明没用完或者没用,<0了说明不够用

我给出我在力扣上跑通的代码:

bool isStraight(vector<int>& nums) {
        //普通思路,先排序,找到大小王个数,有对子直接返回false,
        //判断相邻两个是不是顺子,是就往下判断,不是了用大小王替换缺的牌
        //因为最多两张王,如果要替换的缺的牌大于有的王,那么说明肯定不是顺子
        sort(nums.begin(),nums.end());
        int index=0;
        int zero=0;
        while(index<nums.size()&&nums[index]==0)
        {
            index++;
            zero++;
        }
        for(int i=index;i<nums.size()-1;++i)
        {
            if(nums[i]==nums[i+1])return false;//有对子直接返回
            else if(nums[i]+1==nums[i+1])//相邻的相同
            {
               continue;
            }
            else
            {   //关键看大小王能替换几张牌
                //比如有两张王 0 0 1 2 5
                //zero=2    用王来替代2到5缺的几张牌
                //zero-=5-2-1(缺两张) --->zero=2-2=0  ok的
                zero-=(nums[i+1]-nums[i]-1);
                //zero=1    0  1 2 3 7
                            //zero=1-(7-3-1)=-2王不够
            }    
            if(zero<0)  //最后看看王换完如果小于0了,说明缺的牌肯定大于现有的王
                        //一定组不成顺子
            return false;
        }
        return zero>=0;

写完之后过了,因为这是一道简单题,我还写了半天,通过之后没用沾沾自喜。去看题解,感觉自己的智商被侮辱了,我做的这么多if判断,被大佬一句最大-最小<5返回给打败了

我下来说说大佬的思路:

  1. 不用排序,用set去遍历判断重复
  2. 遇到0了直接跳过,我们set需要的是非0的牌,且如果重复了说明是对子,直接返回false
  3. 两个变量保存最大牌和最小牌
  4. 返回如果最大牌-最小牌<5即能构成顺子

 图片来自题解区k神

关键在于max-min<5,这个条件自己好好几组数字就能明白,我真的笨啊没想到

这式子就无关大小王了

代码放着:

   bool isStraight(vector<int>& nums) {
        int mins=INT_MAX;
        int maxs=INT_MIN;
        unordered_set<int>ss;
        for(auto x:nums)
        {
            if(x==0)//大小王就跳过了
            {
                continue;
            }   
        
            maxs=max(maxs,x);
            mins=min(mins,x);
            if(ss.count(x))return false;//有重复,说明是对子  
            ss.insert(x);
        }
        return maxs-mins<5;
    }

今晚世界杯决赛,这个时候阿根廷2:0法国

看球去咯

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/99936.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

对DataFrame的列标签增加后缀的DataFrame.add_suffix()方法

【小白从小学Python、C、Java】 【计算机等级考试500强双证书】 【Python-数据分析】 为DataFrame的列标签增加后缀 DataFrame.add_suffix() [太阳]选择题 关于以下python代码说法错误的一项是? import pandas as pd df pd.DataFrame({"A": [1,2],"B":[1…

基于Unity整合BEPUphysicsint物理引擎实战

上一节我们详细的讲解BEPUphysicsint 的物理事件。此物理引擎会产生了碰撞事件与非碰撞事件&#xff0c;碰撞事件大家好理解&#xff0c;非碰撞事件例如: 物理Entity的update事件,Entity的activation/deactivation事件等。本节课来实战如何编译BEPUphysicsint源码到自己的项目,…

Linux 服务器数据同步利器

一、简介 1 认识 Rsync&#xff08;remote synchronize&#xff09;是一个远程数据同步工具&#xff0c;可通过LAN/WAN快速同步多台主机间的文件。Rsync使用所谓的“Rsync算法”来使本地和远 程两个主机之间的文件达到同步&#xff0c;这个算法只传送两个文件的不同部分&#x…

【毕业设计_课程设计】基于机器视觉的害虫种类及数量检测(源码+论文)

文章目录0 项目说明1 研究目的2 研究内容及结论3 文件介绍4 论文目录5 项目源码0 项目说明 基于机器视觉的害虫种类及数量检测 提示&#xff1a;适合用于课程设计或毕业设计&#xff0c;工作量达标&#xff0c;源码开放 1 研究目的 研究的目的在于建立一套远程病虫害自动识别…

UNION 和 UNION ALL

合并查询结果 利用UNION关键字&#xff0c;可以给出多条SELECT语句&#xff0c;并将它们的结果组合成单个结果集。合并时&#xff0c;两个表对应的列数和数据类型必须相同&#xff0c;并且相互对应。 各个SELECT语句之间使用UNION或UNION ALL关键字分隔。 语法格式 SELECT c…

(附源码)node.js外卖平台 毕业设计 151448

摘 要 随着科学技术的飞速发展&#xff0c;各行各业都在努力与现代先进技术接轨&#xff0c;通过科技手段提高自身的优势&#xff1b;对于外卖平台当然也不能排除在外&#xff0c;随着网络技术的不断成熟&#xff0c;带动了外卖平台&#xff0c;它彻底改变了过去传统的管理方式…

神州数码交换机CS6200命令(二)

神州数码交换机CS6200命令&#xff08;二&#xff09; 1.基于流的重定向 QOS(Quality of Servcie)-服务品质保障&#xff0c;不产生新的带宽而是根据需求控制带宽 简易配置顺序&#xff1a; 1.配置分类表(class map) 对数据建立一个分类规则 2.配置策略表(policy map) 对…

左(9)--题目讲解

前言 仅记录学习笔记&#xff0c;如有错误欢迎指正。 题目&#xff1a; leetcode的洗衣机问题 思路&#xff1a; 首先看能不能数量相等 总和%机器数量 0 然后分情况讨论&#xff1a;对于任何一个位置都有至少需要搬动n次&#xff0c;最大值就是答案&#xff01; 题目2&am…

APT最佳学习案例:写个简易版 ButterKnife

前言 目的&#xff1a;写个简易版 ButterKnife&#xff0c;借手写 ButterKnife 去了解如何实现注解、annotationProcessor 的等使用。 先看下butterknife的结构&#xff1a; 源码地址 https://github.com/LucasXu01/MyButterKnife ButterKnife的使用 在build.gradle添加依…

Java : 详解八种基本数据类型的包装类

Java &#xff1a; 详解八种基本数据类型的包装类 每博一文案 人生路漫漫越长大&#xff0c;越明白每个人的路都是漫长而艰辛的。无论我们有多累&#xff0c;我们都无路可退。 就像马丁说的那样&#xff1a;每一个强大的人都曾咬着牙度过一段&#xff0c;没人帮忙&#xff0c;…

Rabbitmq与交换机

目录 一、交换机简介 1、Exchange(交换机)的作用 2、Exchange(交换机)的类型 3、交换机的属性 二、交换机的使用 1、创建项目 2、给子模块添加依赖( rabbitmq-provider、 rabbitmq-consumer) 3、直连交换机(Direct Exchange)使用 4、主题交换机(Topic Exchange)的使用 5、…

【图像分割】和声搜索算法图像多级阈值分割【含Matlab源码 2044期】

⛄一、和声搜索算法的图像阈值寻优算法简介 苹果图像识别是指将苹果果实从枝叶、土壤、天空等背景中分离出来, 即图像分割。最大类间方差法 (OTSU算法)是由日本学者大津展之 (OTSU) 提出的全局阈值选取方法。该方法存在缺乏自适应性、易造成噪声干扰和过分割现象、运算需要大量…

[附源码]计算机毕业设计Python的项目管理系统(程序+源码+LW文档)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程 项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等…

Kafka 安装 快速入门

Kafka 安装 快速入门 Apache Kafka是流行的用于大规模收集、处理、存储和分析数据的开源流处理系统。它以其卓越的性能、低延迟、容错和高吞吐量而闻名&#xff0c;能够每秒处理数千条消息。常用来构建数据管道、利用实时数据流、实现系统监控、数据集成。 如上图&#xff0c;…

【MindStudio训练营第一季】基于MindX的U-Net网络的工业质检实践作业

1.1 作业介绍 1.1.1 作业背景 随着新一轮科技革命和产业变革的加速演进&#xff0c;全球各国都在借助新技术推动制造业升级&#xff0c;从工业2.0自动化开始兴起&#xff0c;到工业3.0信息化普及&#xff0c;如今正迈向工业4.0智能化。借助IoT、工业大数据、人工智能等先进技…

“==” 操作符 与 equals 方法的区别,toString

“” 操作符 与 equals 方法的区别&#xff0c;toString 每博一文案 读过这样一段话&#xff1a;很多人都羡慕我的坚强独立&#xff0c;夸赞我的善解人意。无论什么事情&#xff0c; 我都会把别人放在首位&#xff0c;宁愿自己吃亏&#xff0c;也会尽力满足别人的需求&#xf…

Allegro关闭线段显示不连续效果操作指导

Allegro关闭线段显示不连续效果操作指导 用Allegro进行PCB设计的时候偶尔会出现线段不连续的情况,尤其是在线段拐弯处,实际上并不是线段没有连接上,只是一个显示效果而已,如下图 如何去关闭这个显示效果,具体操作如下 选择Setup-Design Parameter 选择Display 取消勾…

java中实现分页的常见几种方式

文章目录1. 前言2. 先说结论3. 例子1. 数据库SQL的限制条件(limit、fetch&#xff09;2. 使用List集合的截取功能实现3. 插件PageHelper1. 前言 无论是自我学习中&#xff0c;还是在工作中&#xff0c;固然会遇到与前端搭配实现分页的功能&#xff0c;发现有几种方式&#xff…

IIC总线(二)-----IIC控制器与MPU6050

1.Exynos_4412下的IIC控制器 Exynos 4412 SCP简化指令集计算机&#xff08;RISC&#xff09;微处理器支持四个多主控间集成电路&#xff08;I2C&#xff09;总线串行接口。为了在连接到I2C总线的总线主机和外围设备之间传输信息&#xff0c;我们使用了一条专用的串行数据线&am…

IO流(一)

IO流的思维导图如下所示&#xff1a; 我们下来对文件、IO流原理及流的分类&#xff0c;节点流&#xff08;访问文件的、访问数组的、访问管道的&#xff09;和处理流&#xff08;缓冲流、对象流、管道流&#xff09;&#xff0c;输入流&#xff08;InputStream和Reader)和输出流…