当前位置:首页 > JAVA > 正文内容

扑克牌中的顺子 - 算法 Java 实现版

高老师2年前 (2023-10-12)JAVA579

在扑克牌游戏中,我们有时需要判断一手牌是否是一个顺子,也就是判断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"。


扫描二维码推送至手机访问。

版权声明:本文由高久峰个人博客发布,如需转载请注明出处。

本文链接:https://blog.20230611.cn/post/648.html

分享给朋友:

“扑克牌中的顺子 - 算法 Java 实现版” 的相关文章

java编译编码问题,java编译执行时编码问题

java编译编码问题,java编译执行时编码问题

public class test {     public static void main(String[] args) {     &...

java final 修饰符,java通过final修饰符创建常量,,java通过final修饰符声明方法不可被修改

java final 修饰符,java通过final修饰符创建常量,,java通过final修饰符声明方法不可被修改

(1).final 修饰符通常和 static 修饰符一起使用来创建类常量。(2).父类中的 final 方法可以被子类继承,但是不能被子类重写,声明 final 方法的主要目的是防止该方法的内容被修改。public class Member {   ...

java正则表达式判断字符串是否包含,java判断字符串是否包含

java正则表达式判断字符串是否包含,java判断字符串是否包含

pattern表示正则表达式,接收正则表达式作为参数例子:String content = "my name is gaojiufeng"; String pattern = "....

java正则表达式捕获组

java正则表达式捕获组

java正则表达式的捕获组捕获组可以将匹配到的结果根据正则中的括号进行分组,这里变量我加了$符,php转java的坏习惯,懒得改了,能跑就行// 匹配字符串 String $line = "gaojiufeng 1994! ok?...

java lookingAt匹配字符串和java matches匹配字符串,java正则replaceAll,java正则replaceFirst

java lookingAt匹配字符串和java matches匹配字符串,java正则replaceAll,java正则replaceFirst

(4).java lookingAt匹配字符串和java matches匹配字符串lookingAt不要求整个字符串全匹配,例如me和me_you都是匹配的,但是lookingAt从第一个字符串开始匹配,匹配失败了也不会继续匹配,意味着me和you_me是无法匹配的matches匹配字符串要求全部匹...

java正则appendReplacement方法和java正则appendTail

java正则appendReplacement方法和java正则appendTail

假如有个字符串为"fatcatfatcatfat",正则为“cat”当调用appendReplacement(sb, "dog")时appendReplacement方法都会把匹配到的内容替换为dog,并把匹配到字符串的前面几个字符串+dog送给sb里,所以第...