Pipes實現(xiàn)LeetCode(193.驗證電話號碼)
[LeetCode] 193.Valid Phone Numbers 驗證電話號碼
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
這道題讓我們驗證數(shù)字串是否為正確的電話號碼的格式,而且規(guī)定了正確的格式只有兩種(xxx) xxx-xxxx or xxx-xxx-xxxx,那么我們可以看出來區(qū)別就是在前幾個字符,而后八個字符都相同。這題有多種解法,我們首先來看使用awk命令的解法。這道題是難點是如何寫匹配的正則表達式。那么首先來看‘/.../'表示中間的是要匹配的正則表達式,然后脫字符^匹配一行的開頭,美元符$在正則表達式中匹配行尾,然后再看中間的部分,[0-9]{3}表示匹配三個數(shù)字,圓括號括起一組正則表達式. 它和"|"操作符或在用expr進行子字符串提取(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命令的解法。那么我們先來看后面的兩個參數(shù),-n表示關(guān)閉默認輸出,默認將自動打印所有行,這樣就不會打印出不符合要求的數(shù)字串了。-r表示支持擴展正則+ ? () {} |。后面的正則表達式和上面都相同,就是后面多了一個p,在用sed時,p和-n合用,表示打印某一行,這樣才能把符合要求的行打印出來:
解法二:
sed -n -r '/^([0-9]{3}-|\([0-9]{3}\) )[0-9]{3}-[0-9]{4}$/p' file.txt
再來看使用grep命令的做法。我沒有查到那個-P參數(shù)的用法,有沒有大神來點撥一下,后面的正則表達式思路根上面的相同,只不過用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實現(xiàn)LeetCode(193.驗證電話號碼)的文章就介紹到這了,更多相關(guān)Pipes實現(xiàn)驗證電話號碼內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言實現(xiàn)查詢自動售貨機中的商品價格【實例分享】
本文主要介紹了C語言實現(xiàn)查詢自動售貨機中的商品價格的相關(guān)資料。具有很好的參考價值。下面跟著小編一起來看下吧2017-04-04
VisualStudio2019構(gòu)建C/C++靜態(tài)庫和動態(tài)庫dll的問題 附源碼
這篇文章主要介紹了VisualStudio2019構(gòu)建C/C++靜態(tài)庫和動態(tài)庫(dll)(文末附源碼),本文通過實例圖文相結(jié)合給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03
va_list(),va_start(),va_arg(),va_end() 詳細解析
這些宏定義在stdarg.h中,所以用到可變參數(shù)的程序應(yīng)該包含這個頭文件.下面我們寫一個簡單的可變參數(shù)的函數(shù),該函數(shù)至少有一個整數(shù)參數(shù),第二個參數(shù)也是整數(shù),是可選的.函數(shù)只是打印這兩個參數(shù)的值2013-09-09
詳解C++循環(huán)創(chuàng)建多級目錄及判斷目錄是否存在的方法
這篇文章主要介紹了C++循環(huán)創(chuàng)建多級目錄及判斷目錄是否存在的方法,文中代碼有一個針對各種系統(tǒng)進行判斷來加載不同頭文件的方法,需要的朋友可以參考下2016-03-03

