亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

正則表達式 零寬斷言該怎么理解?

正則表達式 零寬斷言該怎么理解?

PIPIONE 2018-08-10 10:09:36
Regex Golf上的兩道題:第五題要求排除包含abba格式子字符串的字符串,如abba,commotive,trillion……其中一個正確答案是/^(?!.*(.)(.)\2\1)/abba格式用/(.)(.)\2\1/比較好解決,排除則是用的零寬斷言的(?!exp),然后我對整個表達式理解的是:“開頭位置之后跟的不是任意個字符+abba字符的字符串”,但如果這么理解的話,反過來“結尾位置之前不是abba字符+任意個字符的字符串”,即表達式/(?!(.)(.)\2\1.*)$/應該也是成立的啊,然而事實是這個表達式是錯誤的。同樣對于第七題,要求匹配內容為素數個x的字符串,如xx,xxx,xxxxx……某一個正確答案是^(?!(xx+)\1+$),思路就是排除有大于等于2的因數的數目同樣我覺得(?!^(xx+)\1+)$應該也是可以的啊,但事實上這也是個錯誤答案。。。感覺應該是自己對零寬斷言理解不到位,但具體什么錯在哪一直沒能理解,求告知~以及,是不是真的有必要把正則研究到Regex Golf題目的那種程度?
查看完整描述

1 回答

?
慕虎7371278

TA貢獻1802條經驗 獲得超4個贊

匹配1,要求后面不是2,這么用 /1(?!2)/
你那種寫法是 要求后面不是2,但是沒匹配任何東西,不管什么字符串,總能找到后面不是2的地方

查看完整回答
反對 回復 2018-09-16
  • 1 回答
  • 0 關注
  • 575 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號