3 回答

TA貢獻(xiàn)1856條經(jīng)驗 獲得超17個贊
通常,編寫不包含特定字符串的正則表達(dá)式很麻煩。我們必須對計算模型執(zhí)行此操作-您可以使用很容易定義的NFA,然后將其簡化為正則表達(dá)式。不包含“ cat”的內(nèi)容的表達(dá)式大約有80個字符。
編輯:我剛剛完成,是的,它是:
aa([^a] | a[^a])aa
這是一個非常簡短的教程。我之前找到了一些很棒的東西,但是我再也看不到它們了。

TA貢獻(xiàn)2051條經(jīng)驗 獲得超10個贊
您需要的只是一個勉強的量詞:
regex: /aa.*?aa/
aabbabcaabda => aabbabcaa
aaaaaabda => aaaa
aabbabcaabda => aabbabcaa
aababaaaabdaa => aababaa, aabdaa
您也可以使用否定的前瞻,但是在這種情況下,這只是完成同一件事的一種更冗長的方式。而且,這比gpojd提出來的要復(fù)雜一些。在允許該點消耗下一個字符之前,必須在每個位置上應(yīng)用前瞻。
/aa(?:(?!aa).)*aa/
至于Claudiu和finnw建議的方法,當(dāng)前哨字符串只有兩個字符長時,它可以正常工作,但是(如Claudiu所承認(rèn)的那樣)對于較長的字符串來說太笨拙了。
- 3 回答
- 0 關(guān)注
- 4598 瀏覽
添加回答
舉報