【剑指Offer】44、扑克牌顺子

题目描述:

LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是54张^_^)...他随机从中抽出了5张牌,想测测自己的手气,看看能不能抽到顺子,如果抽到的话,他决定去买体育彩票,嘿嘿!!“红心A,黑桃3,小王,大王,方片5”,“Oh My God!”不是顺子.....LL不高兴了,他想了想,决定大\小 王可以看成任何数字,并且A看作1,J为11,Q为12,K为13。上面的5张牌就可以变成“1,2,3,4,5”(大小王分别看作2和4),“So Lucky!”。LL决定去买体育彩票啦。 现在,要求你使用这幅牌模拟上面的过程,然后告诉我们LL的运气如何, 如果牌能组成顺子就输出true,否则就输出false。为了方便起见,你可以认为大小王是0。

题解:INT位存放扑克牌数字
 1 /*
 2     必须满足两个条件
 3     1. 除0外没有重复的数
 4     2. max - min < 5
 5      */
 6     public static boolean isContinuous(int [] numbers) {
 7         if(numbers.length!=5){
 8             return false;
 9         }
10         int min=14,max=-1,byteOfNums=0;//byteOfNums为int数据,共32位
11         for(int i = 0; i < numbers.length; i++) {
12             int number = numbers[i];
13             if(number < 0 || number > 13) return false;
14             if(number == 0) continue;
15             if(((byteOfNums>> number) & 1) == 1) return false;//保证不能重复
16             byteOfNums |= (1 << number);//更新并存放数字
17             //分别找出数组中最小值与最大值
18             ///System.out.println(byteOfNums);//?1 0101 0000 0000?=5376
19             if(number > max) max = number;
20             if(number < min) min = number;
21             if(max - min >= 5) return false;
22         }
23         return true;
24     }
25     public static boolean isContinuous01(int [] numbers) {
26         int[] d = new int[14];//存放数字
27         d[0] = -5;
28         int len = numbers.length;
29         int max = -1;
30         int min = 14;
31         for(int i =0;i<len;i++){
32             d[numbers[i]]++;
33             if(numbers[i] == 0){
34                 continue;
35             }
36             if(d[numbers[i]]>1){//出现重复
37                 return false;
38             }
39             if(numbers[i] >max){
40                 max = numbers[i];
41             } if(numbers[i] <min){
42                 min = numbers[i];
43             }
44
45         }
46         if(max -min<5){
47             return true;
48         }
49         return false;
50     }
1 //测试
2   public static void main(String[] args) {
3         int[] nums={8,10,12,0,0};
4         boolean b = isContinuous(nums);
5         boolean b1 = isContinuous01(nums);
6         System.out.println(b);
7         System.out.println(b1);
8     }

原文地址:https://www.cnblogs.com/Blog-cpc/p/12308360.html

时间: 2024-08-02 00:20:08

【剑指Offer】44、扑克牌顺子的相关文章

剑指offer (44) 扑克牌的顺子

题目:从扑克牌中随机抽取5张牌,判断是不是一个顺子,即这5张牌是不是连续的 2-10为数字本身,A为1,J为11,Q为12,K为13,大小王可以替换任意数字 题解分析: step1. 首先大小王看作0,与其他数字都区分开 step2. 对这5张牌排序 step3. 统计5张牌中0的个数和 相邻数字之间的空缺总数,因为 我们可以把0替换掉空缺所需的数 bool IsContinuous(std::vector<int>& num) { if (num.size() != 5) retur

【剑指offer】扑克牌顺子

题目链接:扑克牌顺子 题意:LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是54张^_^)...他随机从中抽出了5张牌,想测测自己的手气,看看能不能抽到顺子,如果抽到的话,他决定去买体育彩票,嘿嘿!!“红心A,黑桃3,小王,大王,方片5”,“Oh My God!”不是顺子.....LL不高兴了,他想了想,决定大\小 王可以看成任何数字,并且A看作1,J为11,Q为12,K为13.上面的5张牌就可以变成“1,2,3,4,5”(大小王分别看作2和4),“So

剑指offer:扑克牌顺子

http://wiki.jikexueyuan.com/project/for-offer/question-forty-four.html 题目:从扑克牌中随机抽 5 张牌,判断是不是一个顺子, 即这 5 张牌是不是连续的.2-10 为数字本身, A 为 1. J 为 11.Q 为 12. 为 13.小王可以看成任意数字. 首先把数组排序, 记录非0的最小值和最大值, 如果连起来则需要满足: 1)数组中不能有重复值(没有对子) 2)max-min<=4 public static boolea

《剑指offer》扑克牌顺子

[ 声明:版权所有,转载请标明出处,请勿用于商业用途.  联系信箱:[email protected]] 题目链接:http://www.nowcoder.com/practice/762836f4d43d43ca9deb273b3de8e1f4?rp=3&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking 题目描述 LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是

[剑指Offer] 45.扑克牌顺子

题目描述 LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是54张^_^)...他随机从中抽出了5张牌,想测测自己的手气,看看能不能抽到顺子,如果抽到的话,他决定去买体育彩票,嘿嘿!!"红心A,黑桃3,小王,大王,方片5","Oh My God!"不是顺子.....LL不高兴了,他想了想,决定大/小王可以看成任何数字,并且A看作1,J为11,Q为12,K为13.上面的5张牌就可以变成"1,2,3,4,5"(

【剑指offer】扑克牌的顺子

转载请注明出处:http://blog.csdn.net/ns_code/article/details/27849055 题目描写叙述: LL今天心情特别好,由于他去买了一副扑克牌,发现里面竟然有2个大王,2个小王(一副牌原本是54张^_^)...他随机从中抽出了5张牌,想測測自己的手气,看看能不能抽到顺子,假设抽到的话,他决定去买体育彩票,嘿嘿!."红心A,黑桃3,小王,大王,方片5","Oh My God!"不是顺子.....LL不高兴了,他想了想,决定大\小

剑指offer45:扑克牌顺子

1 题目描述 LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是54张^_^)...他随机从中抽出了5张牌,想测测自己的手气,看看能不能抽到顺子,如果抽到的话,他决定去买体育彩票,嘿嘿!!“红心A,黑桃3,小王,大王,方片5”,“Oh My God!”不是顺子.....LL不高兴了,他想了想,决定大\小 王可以看成任何数字,并且A看作1,J为11,Q为12,K为13.上面的5张牌就可以变成“1,2,3,4,5”(大小王分别看作2和4),“So Lucky!

[剑指Offer] 44.翻转单词顺序列

题目描述 牛客最近来了一个新员工Fish,每天早晨总是会拿着一本英文杂志,写些句子在本子上.同事Cat对Fish写的内容颇感兴趣,有一天他向Fish借来翻看,但却读不懂它的意思.例如,"student. a am I".后来才意识到,这家伙原来把句子单词的顺序翻转了,正确的句子应该是"I am a student.".Cat对一一的翻转这些单词顺序可不在行,你能帮助他么? [思路]先把由空格分割的每个字符串翻转,最后翻转整个字符串. 1 class Solution

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

def IsContinuous(seq, num = 5): zeros = 0; d = 0 seq = sorted(seq) for i in range(num - 1): if seq[i] == 0: zeros += 1 continue if seq[i] == seq[i + 1]: return False d += seq[i + 1] - seq[i] - 1 return zeros >= d [剑指offer]:Q44:扑克牌的顺子,布布扣,bubuko.com

剑指 Offer 题目汇总索引

剑指 Offer 总目录:(共50道大题) 1. 赋值运算符函数(或应说复制拷贝函数问题) 2. 实现 Singleton 模式 (C#) 3.二维数组中的查找 4.替换空格               时间:O(n) 空间:O(1) 5.从尾到头打印链表 6. 重建二叉树          && 二叉树的各种遍历(BFS,DFS,DLR,LDR,LRD) 7.用两个栈实现队列 8.旋转数组的最小数字 9.斐波那契数列第 n 项        时间O(lgn) 10.一个整数的二进制表示中