如何编写正则表达式,其中x是一个字符串,其字符为a,b,c但没有两个连续的字符是相同的
例如
abcacb是真的
acbaac是假的
答案 0 :(得分:2)
^(?!.*(.)\1)[abc]+$
可以正常工作。但是,这不工作/检查字符a / b / c的多个“单词”,即。 “abc cba”。
它的工作方式是断言任何字符都不会通过利用前瞻中的捕获组来跟随它,并且整个字符串只包含字符“a”,“b”或“c”。
答案 1 :(得分:1)
由于字符数量有限,你可以在前面没有后退参考的情况下离开:
^(?!.*(aa|bb|cc)[abc]*$
但我更喜欢tenub的答案:)