Pipes實(shí)現(xiàn)LeetCode(193.驗(yàn)證電話號(hào)碼)
[LeetCode] 193.Valid Phone Numbers 驗(yàn)證電話號(hào)碼
Given a text file file.txt that contains list of phone numbers (one per line), write a one liner bash script to print all valid phone numbers.
You may assume that a valid phone number must appear in one of the following two formats: (xxx) xxx-xxxx or xxx-xxx-xxxx. (x means a digit)
You may also assume each line in the text file must not contain leading or trailing white spaces.
For example, assume that file.txt has the following content:
987-123-4567
123 456 7890
(123) 456-7890
Your script should output the following valid phone numbers:
987-123-4567
(123) 456-7890
這道題讓我們驗(yàn)證數(shù)字串是否為正確的電話號(hào)碼的格式,而且規(guī)定了正確的格式只有兩種(xxx) xxx-xxxx or xxx-xxx-xxxx,那么我們可以看出來區(qū)別就是在前幾個(gè)字符,而后八個(gè)字符都相同。這題有多種解法,我們首先來看使用awk命令的解法。這道題是難點(diǎn)是如何寫匹配的正則表達(dá)式。那么首先來看‘/.../'表示中間的是要匹配的正則表達(dá)式,然后脫字符^匹配一行的開頭,美元符$在正則表達(dá)式中匹配行尾,然后再看中間的部分,[0-9]{3}表示匹配三個(gè)數(shù)字,圓括號(hào)括起一組正則表達(dá)式. 它和"|"操作符或在用expr進(jìn)行子字符串提取(substring extraction)一起使用很有用。那么([0-9]{3}-|\([0-9]{3}\) )就可以理解了,它匹配了xxx-和(xxx) 這兩種形式的字符串,然后后面的就好理解了,匹配xxx-xxxx這樣的字符串,參見代碼如下:
解法一:
awk '/^([0-9]{3}-|\([0-9]{3}\) )[0-9]{3}-[0-9]{4}$/' file.txt
下面來看使用sed命令的解法。那么我們先來看后面的兩個(gè)參數(shù),-n表示關(guān)閉默認(rèn)輸出,默認(rèn)將自動(dòng)打印所有行,這樣就不會(huì)打印出不符合要求的數(shù)字串了。-r表示支持?jǐn)U展正則+ ? () {} |。后面的正則表達(dá)式和上面都相同,就是后面多了一個(gè)p,在用sed時(shí),p和-n合用,表示打印某一行,這樣才能把符合要求的行打印出來:
解法二:
sed -n -r '/^([0-9]{3}-|\([0-9]{3}\) )[0-9]{3}-[0-9]{4}$/p' file.txt
再來看使用grep命令的做法。我沒有查到那個(gè)-P參數(shù)的用法,有沒有大神來點(diǎn)撥一下,后面的正則表達(dá)式思路根上面的相同,只不過用d{3}來表示[0-9]{3},道理都一樣,參見代碼如下:
解法三:
grep -P '^(\d{3}-|\(\d{3}\) )\d{3}-\d{4}$' file.txt
參考資料:
https://leetcode.com/discuss/29282/this-is-my-simple-solution
https://leetcode.com/discuss/29476/three-different-solutions-using-grep-sed-and-awk
到此這篇關(guān)于Pipes實(shí)現(xiàn)LeetCode(193.驗(yàn)證電話號(hào)碼)的文章就介紹到這了,更多相關(guān)Pipes實(shí)現(xiàn)驗(yàn)證電話號(hào)碼內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Pipes實(shí)現(xiàn)LeetCode(194.轉(zhuǎn)置文件)
- Pipes實(shí)現(xiàn)LeetCode(195.第十行)
- Pipes實(shí)現(xiàn)LeetCode(192.單詞頻率)
- C++實(shí)現(xiàn)LeetCode(191.位1的個(gè)數(shù))
- C++實(shí)現(xiàn)LeetCode(190.顛倒二進(jìn)制位)
- C++實(shí)現(xiàn)LeetCode(309.買股票的最佳時(shí)間含冷凍期)
- C++實(shí)現(xiàn)LeetCode(188.買賣股票的最佳時(shí)間之四)
- SQL實(shí)現(xiàn)LeetCode(196.刪除重復(fù)郵箱)
相關(guān)文章
Visual Studio 2022最新版安裝教程(圖文詳解)
本文主要介紹了Visual Studio 2022最新版安裝教程,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01原碼, 反碼與補(bǔ)碼基礎(chǔ)知識(shí)詳細(xì)介紹
這篇文章講解了計(jì)算機(jī)的原碼, 反碼和補(bǔ)碼. 并且進(jìn)行了深入探求了為何要使用反碼和補(bǔ)碼, 以及更進(jìn)一步的論證了為何可以用反碼, 補(bǔ)碼的加法計(jì)算原碼的減法,需要的朋友可以參考下2016-12-12C++實(shí)現(xiàn)LeetCode(79.詞語搜索)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(79.詞語搜索),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07C語言實(shí)現(xiàn)經(jīng)典掃雷小游戲的示例代碼
掃雷游戲是在一個(gè)指定的二維空間里,隨機(jī)布置雷,把不是雷的位置都找出來,在你點(diǎn)一個(gè)位置的時(shí)候它會(huì)顯示它周圍全部雷的個(gè)數(shù),根據(jù)這個(gè)線索去找 ,會(huì)更容易贏。本文將用C語言實(shí)現(xiàn)這一經(jīng)典游戲,感興趣的可以嘗試一下2022-11-11淺談返回函數(shù)內(nèi)部new分配的內(nèi)存的引用
下面小編就為大家?guī)硪黄獪\談返回函數(shù)內(nèi)部new分配的內(nèi)存的引用。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-12-12