佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 檢查素數(shù)的正則表達式分享

檢查素數(shù)的正則表達式分享

熱門標簽:Linux服務(wù)器 阿里云 科大訊飛語音識別系統(tǒng) 電子圍欄 Mysql連接數(shù)設(shè)置 團購網(wǎng)站 銀行業(yè)務(wù) 服務(wù)器配置
這個正則表達式如入所示:

檢查素數(shù)與否的正則表達式

要使用這個正規(guī)則表達式,你需要把自然數(shù)轉(zhuǎn)成多個1的字符串,如:2 要寫成 “11”, 3 要寫成 “111”, 17 要寫成“11111111111111111”,這種工作使用一些腳本語言可以輕松的完成。

一開始我對這個表達式持懷疑態(tài)度,但仔細研究了一下這個表達式,發(fā)現(xiàn)是非常合理的,下面,讓我?guī)銇砑毤毱饰鲆幌率沁@個表達式的工作原理。

首先,我們看到這個表達式中有“|”,也就是說這個表達式可以分成兩個部分:/^1?$/ 和 /^(11+?)\1+$/

  • 第一部分:/^1?$/, 這個部分相信不用我多說了,其表示匹配“空串”以及字串中只有一個“1”的字符串。
  • 第二部分:/^(11+?)\1+$/,這個部分是整個表達式的關(guān)鍵部分。其可以分成兩個部分,(11+?)\1+$,前半部很簡單了,匹配以“11”開頭的并重復(fù)0或n個1的字符串,后面的部分意思是把前半部分作為一個字串去匹配還剩下的字符串1次或多次(這句話的意思是——剩余的字串的1的個數(shù)要是前面字串1個數(shù)的整數(shù)倍)。

可見這個正規(guī)則表達式是取非素數(shù),要得到素數(shù)還得要對整個表達式求反。通過上面的分析,我們知道,第二部分是最重要的,對于第二部分,舉幾個例子,

示例一:判斷自然數(shù)8。我們可以知道,8轉(zhuǎn)成我們的格式就是“11111111”,對于(11+?),其匹配了“11”,于是還剩下“111111”,而\1+$正好匹配了剩下的“111111”,因為,“11”這個模式在“111111”出現(xiàn)了三次,符合模式匹配,返回true。所以,匹配成功,于是這個數(shù)不是質(zhì)數(shù)。

示例二:判斷自然數(shù)11。轉(zhuǎn)成我們需要的格式是“11111111111”(十一個1),對于(11+?),其匹配了“11”(前兩個1),還剩下“111111111”(九個1),而\1+$無法為“11”匹配那“九個1”,因為“11”這個模式并沒有在“九個1”這個串中正好出現(xiàn)N次。于是,我們的正則表達式引擎會嘗試下一種方法,先匹配“111”(前三個1),然后把“111”作為模式去匹配剩下的“11111111”(八個1),很明顯,那“八個1”并沒有匹配“三個1”多次。所以,引擎會繼續(xù)向下嘗試……直至嘗試所有可能都無法匹配成功。所以11是素數(shù)。

通過示例二,我們可以得到這樣的等價數(shù)算算法,正則表達式會匹配這若干個1中有沒有出現(xiàn)“二個1”的整數(shù)倍,“三個1”的整數(shù)倍,“四個1”的整數(shù)倍……,而,這正好是我們需要的算素數(shù)的算法?,F(xiàn)在大家明白了吧。

下面,我們用perl來使用這個正規(guī)則表達式不停地輸出素數(shù):(關(guān)于perl的語法我就不多說了,請注意表達式前的取反操作符)

perl -e'$|++;(1 x$_)!~/^1?$|^(11+?)\1+$/print"$_ "while ++$_'

另外,讓我們來舉一反三,根據(jù)上述的這種方法,我們甚至可以用正則表達式來求證某方式是否有解,如:

  • 二元方程:17x + 12y = 51   判斷其是否有解的正則表達式是:^(.*)\1{16}(.*)\2{11}$
  • 三元方程:11x + 2y + 5z = 115 判斷其是否有解的正則表達式是:^(.*)\1{10}(.*)\2{1}(.*)\3{4}$

大家不妨自己做做練習,為什么上述的兩個正則表達式可以判斷方程是否有解。如果無法參透其中的奧妙的話,你可以讀讀這篇英文文章。

您可能感興趣的文章:
  • php 求質(zhì)素(素數(shù)) 的實現(xiàn)代碼
  • JS 用6N±1法求素數(shù) 實例教程
  • 用正則表達式來判斷素數(shù)的代碼

標簽:大理 蚌埠 萍鄉(xiāng) 衡水 廣元 衢州 江蘇 棗莊

巨人網(wǎng)絡(luò)通訊聲明:本文標題《檢查素數(shù)的正則表達式分享》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    田阳县| 武乡县| 和硕县| 安达市| 阳西县| 巴东县| 苗栗县| 德昌县| 交城县| 阿坝| 安庆市| 岐山县| 方正县| 汝南县| 嘉黎县| 扎赉特旗| 衡阳市| 钟祥市| 彭水| 花莲市| 尉犁县| 象州县| 沙洋县| 颍上县| 阿巴嘎旗| 秦安县| 神农架林区| 共和县| 景泰县| 阿图什市| 龙里县| 灵宝市| 望都县| 库尔勒市| 全南县| 永靖县| 额尔古纳市| 五莲县| 建昌县| 邵武市| 应城市|