题目描述:

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。

解题思路:

  • 这道题给我们5张牌,让我们判断其是不是顺子,大小王可以抵任何数(大小王以0代表)
  • 我们首先将所给数组以升序排列,然后遍历数组,记录每一位与下一位的最终差的和是否小于5便好
  • 遇见0直接跳过,如果遇见当前位与下一位相等直接返回false便好

解题代码:

  1. function IsContinuous(numbers)
  2. {
  3. // write code here
  4. if(numbers.length < 5) return false;
  5. numbers.sort((a,b) => {
  6. if(a < b) return -1;
  7. if(a > b) return 1;
  8. })
  9. let res = 0;
  10. for(let i = 0;i<numbers.length - 1;i++) {
  11. if(numbers[i] === 0) continue;
  12. if(numbers[i] === numbers[i+1] ) return false;
  13. res += numbers[i+1] - numbers[i];
  14. }
  15. return res < 5;
  16. }