在扑克牌游戏中,我们有时需要判断一手牌是否是一个顺子,也就是判断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"。
java一个类可以有多个构造方法,根据传参类型和个数来匹配执行哪个构造方法。public class Member { public Member(){  ...
java限制1个方法同一时间只能被一个线程访问public synchronized void setOrderPay(){ }加上synchronized 修饰符即可...
Java5 引入了一种主要用于数组的增强型 for 循环,类似js中的for inpublic class Member { public static void main(String[]&...
在java中字符串属于对象,刚开始我就疑惑为什么int char等类型都是小写,结果String是大写,java太反人类,后来才知道String是对象。(1).java创建字符串String text = "net"; String tex...
java stringBuffer(1).stringBuffer和stringBuilder区别stringBuffer是线程安全的,stringBuilder速度更快(2).简单的stringBuffer例子StringBuffer sBuffer = new&nb...
java正则表达式的捕获组捕获组可以将匹配到的结果根据正则中的括号进行分组,这里变量我加了$符,php转java的坏习惯,懒得改了,能跑就行// 匹配字符串 String $line = "gaojiufeng 1994! ok?...