剑指offer-45-扑克牌顺子

扑克牌顺子

http://www.nowcoder.com/questionTerminal/762836f4d43d43ca9deb273b3de8e1f4

思路

  • set集合,有重复直接返回flase,否则max-min<5,注意要去除0的min和max
  • 排序,遍历,等于0记录cnt++,如果number[i]-number[i-1]-1大于cnt,返回false,否则cnt减去对应的值。

代码

import java.util.*;
public class Solution {
    public boolean isContinuous(int [] numbers) {
        if(numbers.length!=5){return false;}
        Set<Integer> set=new HashSet<>();
        int min=14,max=0;
        for(int i=0;i<numbers.length;i++){
            if(numbers[i]!=0){
                if(numbers[i]!=0 && set.contains(numbers[i])){
                    return false;
                }else{
                    set.add(numbers[i]);
                }
                    min=Math.min(min,numbers[i]);
                    max=Math.max(max,numbers[i]);    
            }
        }
        return max-min<5;

    }
}
剑指offer与数据结构 文章被收录于专栏

本专栏包括剑指offer题目和一些刷题用的数据结构,单调栈,树状数组,差分数组,后面还会更新红黑树等较为复杂的数据结构

全部评论

相关推荐

秋盈丶:后续:我在宿舍群里和大学同学分享了这事儿,我好兄弟气不过把他挂到某脉上了,10w+阅读量几百条评论,直接干成精品贴子,爽
点赞 评论 收藏
分享
刘湘_passion:太强了牛肉哥有被激励到
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务