正则表达式匹配字符串中出现a,b,c三个字母各一次并且顺序任意

发布于 2022-09-12 13:58:43 字数 38 浏览 22 评论 0

如题,今天突然想到这么个题目,没想出来答案。请大神们指教一下。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

故事灯 2022-09-19 13:58:43

正向写这个正则太恶心了,需要枚举6种排序方式.但是,如果把你的要求反过来看,就是不能达成 abc三个字母必须出现且只能出现一次 的情况,就必然会满足以下的条件之一:

  • 没有出现 a
  • 没有出现 b
  • 没有出现 c
  • a 至少出现两次
  • b 至少出现两次
  • c 至少出现两次

只要出现以上的六种情况,那么必然就没有达成你的原始要求,那么正则如下:

^([^a]+|[^b]+|[^c]+|([^a]*a[^a]*){2,}|([^b]*b[^b]*){2,}|([^c]*c[^c]*){2,})$

ps. 这个正则如果匹配成功,就说明不符合要求

图示如下:
image.png

我不考虑字符串为空的情况哈,你要考虑自己加上.

北陌 2022-09-19 13:58:43

一个正则太麻烦了,建议个组合判断,非要一个正则,就像下面这样麻烦

demo('abc') // true
demo('acb') // true
demo('bac') // true
demo('bca') // true
demo('cab') // true
demo('cba') // true
demo('cbab') // false
demo('cbabca') // false

function demo (str) {
  let res = /(^([^abc]*a[^abc]*[^abc]*b[^abc]*[^abc]*c[^abc]*)$)|(^([^abc]*a[^abc]*[^abc]*c[^abc]*[^abc]*b[^abc]*)$)|(^([^abc]*b[^abc]*[^abc]*a[^abc]*[^abc]*c[^abc]*)$)|(^([^abc]*b[^abc]*[^abc]*c[^abc]*[^abc]*a[^abc]*)$)|(^([^abc]*c[^abc]*[^abc]*a[^abc]*[^abc]*b[^abc]*)$)|(^([^abc]*c[^abc]*[^abc]*b[^abc]*[^abc]*a[^abc]*)$)/.test(str)
  console.log(str, '=>结果=>', res)
  return res
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文