前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【剑指offer:扑克牌中的顺子】

【剑指offer:扑克牌中的顺子】

作者头像
心谭博客
发布2020-04-21 15:42:08
2450
发布2020-04-21 15:42:08
举报
文章被收录于专栏:YuanXinYuanXin

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

解法

题目说了是 5 张牌,这是很重要的一个点。整体的算法流程是:

  • 对牌按照从小到大的顺序进行排序
  • 初始化 sub 为 0,代表相邻牌之间的面值差的和
  • 遍历全部牌,并进行统计

代码实现如下:

代码语言:javascript
复制
// ac地址:https://leetcode-cn.com/problems/bu-ke-pai-zhong-de-shun-zi-lcof/
// 原文地址:https://xxoo521.com/2020-03-30-is-straight/
/**
 * @param {number[]} nums
 * @return {boolean}
 */
var isStraight = function(nums) {
    nums.sort((a, b) => a - b);
    let sub = 0;
    for (let i = 0; i < 4; ++i) {
        if (nums[i] === 0) continue;
        if (nums[i] === nums[i + 1]) return false;
        sub += nums[i + 1] - nums[i];
    }
    return sub < 5;
};
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-03-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 解法
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档