【java】剑指offer61_扑克牌中的顺子

122 篇文章 0 订阅

题目描述

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

示例 1:

输入: [1,2,3,4,5]
输出: True
示例 2:

输入: [0,0,1,2,5]
输出: True
限制:数组长度为 5 ,数组的数取值为 [0, 13] .

参考解题思路:集合set判断是否有重复元素+遍历数组,有题意可得顺子必须满足以下条件:

  1. 除大小王外,所有牌 无重复 ;
  2. 设此 55 张牌中最大的牌为 max,最小的牌为 min(大小王除外),则需满足:max−min<5

算法过程:

  • 遍历五张牌,遇到大小王(即 0 )直接跳过。
  • 判别重复: 利用 Set 实现遍历判重, Set 的查找方法的时间复杂度为 O(1) ;
  • 获取最大 / 最小的牌: 借助辅助变量 max 和 min ,遍历统计即可。
  • public boolean isStraight(int[] nums) {
            Set<Integer> repeat = new HashSet<>();
            int max = 0, min = 14; // 定义变量记录数组的最大最小值
            for (int i = 0; i <= 4; i++) {
                // 遇到大小王跳过
                if (nums[i] == 0) {
                    continue;
                }
                if (nums[i] > max) {
                    max = nums[i];
                }
                if (nums[i] < min) {
                    min = nums[i];
                }
                // set中是否已经存在该数字--存在立即返回false
                if (repeat.contains(nums[i])) {
                    return false;
                } else {
                    // 否则追加近set
                    repeat.add(nums[i]);
                }
    
            }
            // 判断最大值与最小值的差值是否满足小于5--为真则返回true
            return max - min < 5;
        }

    复杂度分析:
    时间复杂度 O(N) = O(5) = O(1): 其中 N为 nums长度,本题中 N≡5 ;遍历数组使用 O(N) 时间。
    空间复杂度 O(N) = O(5) = O(1) : 用于判重的辅助 Set 使用 O(N)额外空间。

参考思路二:排序+遍历

算法过程:

  • 先对数组执行排序。
  • 判别重复: 排序数组中的相同元素位置相邻,因此可通过遍历数组,判断 nums[i] = nums[i + 1]是否成立来判重。
  • 获取最大 / 最小的牌: 排序后,数组末位元素 nums[4]为最大牌;元素 nums[joker]为最小牌,其中 joker为大小王的数量。
public boolean isStraight(int[] nums) {
        Arrays.sort(nums);
        int joker = 0; // 大小王出现次数
        for (int i = 0; i < 4; i++) {
            if (nums[i] == 0) {
                joker++; // 大小王数量加一
            } else if (nums[i] == nums[i + 1]) {
                // 不是大小王且两个值重复--立即返回false
                return false;
            }
        }
        // 判断最大值与最小值的差值是否满足小于5--为真则返回true
        return nums[4] - nums[joker] < 5;
    }

复杂度分析:
时间复杂度 O(NlogN)=O(5log5)=O(1) : 其中 N 为 nums长度,本题中N≡5 ;数组排序使用O(NlogN) 时间。
空间复杂度 O(1) : 变量 joker使用 O(1) 大小的额外空间。

作者:jyd
链接:https://leetcode-cn.com/problems/bu-ke-pai-zhong-de-shun-zi-lcof/solution/mian-shi-ti-61-bu-ke-pai-zhong-de-shun-zi-ji-he-se/

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值