在扑克牌游戏中,我们有时需要判断一手牌是否是一个顺子,也就是判断5张牌是否连续。这篇文章将为您提供基于 Java 的算法实现,并解释实现过程。
代码实现: 下面是使用Java语言实现判断一手牌是否是顺子的代码:
import java.util.Arrays; public class PokerStraight { public static boolean isStraight(int[] nums) { Arrays.sort(nums); int jokerNum = 0; for (int i = 0; i < nums.length; i++) { if (nums[i] == 0) { jokerNum++; continue; } if (i > 0 && nums[i] == nums[i - 1]) { return false; } } return nums[4] - nums[jokerNum] < 5; } public static void main(String[] args) { int[] nums = {2, 3, 5, 6, 0}; // 示例输入,可根据实际情况修改 boolean result = isStraight(nums); System.out.println("是否为顺子:" + result); } }
解释说明: 主要的判断逻辑与原先的 Go 版本一致。首先,我们对传入的数组进行排序,然后遍历数组进行判断。如果数组中包含大小王(值为0),则将其计数。如果数组中出现重复数字,则返回 false。最后,判断排序后的数组的最大值和最小值之差是否小于5(注意考虑大小王的情况),若满足条件则说明是一个顺子。
示例输出: 对于示例输入 [2, 3, 5, 6, 0]
,程序将会输出 "是否为顺子:true"。
public class test { public static void main(String[] args) { &...
(1).final 修饰符通常和 static 修饰符一起使用来创建类常量。(2).父类中的 final 方法可以被子类继承,但是不能被子类重写,声明 final 方法的主要目的是防止该方法的内容被修改。public class Member {  ...
在java中字符串属于对象,刚开始我就疑惑为什么int char等类型都是小写,结果String是大写,java太反人类,后来才知道String是对象。(1).java创建字符串String text = "net"; String tex...
(1).创建数组double[] myList = new double[size]; //推荐创建方式 double myList[] = new double[size];  ...
java匹配一个字符串在另外一个字符串中出现的次数,java正则start,java正则end// 正则 String pattern = "\\bgao\\b"; // 字符串 String content ...
(4).java lookingAt匹配字符串和java matches匹配字符串lookingAt不要求整个字符串全匹配,例如me和me_you都是匹配的,但是lookingAt从第一个字符串开始匹配,匹配失败了也不会继续匹配,意味着me和you_me是无法匹配的matches匹配字符串要求全部匹...