当前位置: 首页 > 知识库问答 >
问题:

用于匹配扑克手的正则表达式(Java)

龙德海
2023-03-14

这里是雷格克斯队的新秀。

我需要一个与特定牌手匹配的正则表达式(满牌-包含一个等级的三张牌和另一个等级的两张牌的牌手),它应该将其识别为满牌,具有任意顺序的牌和所有牌级(23456789TJQKA)和套装(SHDC)

我甚至不确定regex是正确的工具,所以请告诉我,如果你认为我应该做些别的:)

示例字符串可以如下所示

"KD KC AH AC AD"

(钻石之王,梅花之王,红心王牌,梅花王牌,钻石王牌)

我想出了这个丑陋的正则表达式

(?=.*(([2-9TJQKA])[SHDC]).*\2[SHDC].*\2[SHDC])(?=.*(?!\2)(([2-9TJQKA])[SHDC]).*\4[SHDC].*\4[SHDC]).*

但它似乎不起作用。

共有2个答案

慕阳平
2023-03-14

代替正则表达式,你可以使用番石榴多重映射,检查你是否只有两个不同的秩,然后检查其中一个秩是否有3套。

public class Foo {
    public static void main(String[] a) {
        String s = "KD KC AH AC AD";
        Splitter splitter = Splitter.on(' ');
        System.out.println(checkFullHouse(splitter.split(s)));
    }

    private static boolean checkFullHouse(Iterable<String> in) {
        Multimap<String, Object> m = ArrayListMultimap.create();
        Splitter splitter = Splitter.fixedLength(1);
        in.forEach(s -> {
            List<String> l = Lists.newArrayList(splitter.split(s));
            m.put(l.get(0), l.get(1));
        });
        return m.keySet().size() == 2 && (int) m.keySet().stream().filter(v -> m.get(v).size() == 3).count() == 1;
    }
}
林承悦
2023-03-14

这应该与“满座”相匹配:(编辑:实际上只是你原来的正则表达式,用来忽略这套西装)

(?=.*([2-9TJQKA])[SHDC].*\1[SHDC].*\1[SHDC])(?=.*((?!\1)[2-9TJQKA])[SHDC].*\2[SHDC])

它查找具有第一个前瞻性的“3”序列。第二个展望是寻找“2”序列,其中包括一个负展望,以防止重复匹配。正则表达式完全由两个lookahead组成,这可以防止在实际匹配(并向前移动指针)任何字符时出现的问题-这两个子模式都可以自由匹配字符串中的任何位置。

此处在线演示

 类似资料:
  • 有没有人试图描述与正则表达式匹配的正则表达式? 由于重复的关键字,这个主题几乎不可能在网上找到。 它可能在实际应用程序中不可用,因为支持正则表达式的语言通常具有解析它们的方法,我们可以将其用于验证,以及一种在代码中分隔正则表达式的方法,可用于搜索目的。 但是我仍然想知道匹配所有正则表达式的正则表达式是什么样子的。应该可以写一个。

  • 我们得到了一些这样的内容:

  • 问题内容: 当字符串以数字开头时,我需要匹配,然后是一个点,然后是一个空格和1个或多个大写字符。匹配必须发生在字符串的开头。我有以下字符串。 我尝试过的正则表达式是: 它不匹配。一个有效的正则表达式将对这个问题有什么作用? 问题答案: (对不起,我先前的错误。大脑现在坚定地投入了。嗯,也许。) 这有效: 分解: =字符串开头 =一个或多个数字 (之所以转义,是因为它在字符串中,因此) =文字(或者

  • 问题内容: 我从以下格式的文件中获取输入: 现在,我想在我的Java代码中读取int1,int2,int3和int4。我该如何在Java中使用正则表达式匹配。谢谢。 问题答案: 为了避免空值:

  • 主要内容:基本模式匹配,字符簇,确定重复出现基本模式匹配 一切从最基本的开始。模式,是正则表达式最基本的元素,它们是一组描述字符串特征的字符。模式可以很简单,由普通的字符串组成,也可以非常复杂,往往用特殊的字符表示一个范围内的字符、重复出现,或表示上下文。例如: 这个模式包含一个特殊的字符 ^,表示该模式只匹配那些以 once 开头的字符串。例如该模式与字符串 "once upon a time" 匹配,与 "There once was

  • NowCoder 题目描述 请实现一个函数用来匹配包括 '.' 和 '*' 的正则表达式。模式中的字符 '.' 表示任意一个字符,而 '*' 表示它前面的字符可以出现任意次(包含 0 次)。 在本题中,匹配是指字符串的所有字符匹配整个模式。例如,字符串 "aaa" 与模式 "a.a" 和 "ab*ac*a" 匹配,但是与 "aa.a" 和 "ab*a" 均不匹配。 解题思路 应该注意到,'.' 是