[Advanced Algorithm] - Validate US Telephone Numbers
题目
如果传入字符串是一个有效的美国电话号码,则返回 true.
用户可以在表单中填入一个任意有效美国电话号码. 下面是一些有效号码的例子(还有下面测试时用到的一些变体写法):
555-555-5555
(555)555-5555
(555) 555-5555
555 555 5555
5555555555
1 555 555 5555
在本节中你会看见如 800-692-7753 or 8oo-six427676;laskdjf这样的字符串. 你的任务就是验证前面给出的字符串是否是有效的美国电话号码. 区号是必须有的. 如果字符串中给出了国家代码, 你必须验证其是 1. 如果号码有效就返回 true ; 否则返回 false.
提示
测试用例
telephoneCheck("555-555-5555")应该返回一个布尔值.telephoneCheck("1 555-555-5555")应该返回true.telephoneCheck("1 (555) 555-5555")应该返回true.telephoneCheck("5555555555")应该返回true.telephoneCheck("555-555-5555")应该返回true.telephoneCheck("(555)555-5555")应该返回true.telephoneCheck("1(555)555-5555")应该返回true.telephoneCheck("1 555)555-5555")应该返回false.telephoneCheck("1 555 555 5555")应该返回true.telephoneCheck("1 456 789 4444")应该返回true.telephoneCheck("123**&!!asdf#")应该返回false.telephoneCheck("55555555")应该返回false.telephoneCheck("(6505552368)")应该返回falsetelephoneCheck("2 (757) 622-7382")应该返回false.telephoneCheck("0 (757) 622-7382")应该返回false.telephoneCheck("-1 (757) 622-7382")应该返回falsetelephoneCheck("2 757 622-7382")应该返回false.telephoneCheck("10 (757) 622-7382")应该返回false.telephoneCheck("27576227382")应该返回false.telephoneCheck("(275)76227382")应该返回false.telephoneCheck("2(757)6227382")应该返回false.telephoneCheck("2(757)622-7382")应该返回false.telephoneCheck("555)-555-5555")应该返回false.telephoneCheck("(555-555-5555")应该返回false.
分析思路
- 分析该题,主要是分析电话号码的有效排列方式,有效的号码规则如下:
- 分离
国家码-区号-电话号,格式如1-555-555-5555,其中每个分段中间是不能被分割的,如1-55-5-555-5555是非法的;- 在不能分段的每个区域中和两头,空格是可以随意加的(任意个),如:
1 555 555 5555、155555555555是合法的;- 在不能分段的每个区域中,中划线是可以加一个的,如:
1-555-555-5555、1 - 555-555 - 5555、1 - 555-5555555是合法的,1-555--555-5555是非法的;- 在区号上可以加小括号,而且必须配对,括号中间允许出现空格在数字两边,如:
1(555)555 5555、1( 555 )5555555是合法的,1 555) 555 5555是非法的;- 除了以上分隔符和数字,其他任意符号都是非法的,如:
1a(555)555 5555、1(555) 555 5555$都是非法的;- 数字必须限制在 10 个(无国家码)/11个,如:
1 555 5555 5555是非法的;- 国家码可以不存在,存在则必须为1,如:
(555) 555 5555、1 555 555 5555是合法的,而2 555 555 5555是非法的;
- 正则表达式编写
- 数字分段匹配,
[\d]{3}这样就是匹配连续三个数字,通过该方式,可以匹配数字分段和数字数目;?匹配符,匹配一个或0个前面的符号,如:[-]?,匹配一个或0个中划线;*匹配符,匹配0个或多个前面的符号,如:[\s]*,匹配0个或多个空格;^、$两个符号分别表示字符串首匹配和字符串尾匹配,两个均加入表示从串首匹配到串尾,如:^[\d]{3}[-][\d]{3}-[\d]{4}$这个正则式,555-555-5555是匹配的,但a55-555-5555、555-555-55555等都是不匹配的;
综上,所以得到的正则匹配表达式如代码说明
代码
function telephoneCheck(str) {
// Good luck!
var regStr = /^[\s]*[\d]?[\s]*[-]?[\s]*[(]?[\s]*[\d]{3}[\s]*[)]?[\s]*[-]?[\s]*[\d]{3}[\s]*[-]?[\s]*[\d]{4}[\s]*$/;
if (regStr.test(str)) { // 匹配数目和号码串格式
if ((/[(]/.test(str) && /[)]/.test(str)) || // 如果有(),检查括号的配对
(!(/[(]/.test(str)) && !(/[)]/.test(str)))) { // 无(),就不能存在任意括号符号
if (str.replace(/[\s-()]*/g, "").length > 10) { // 长度判断,判断国家是否存在,若存在是否正确
return (str[0] === "1");
}
return true;
}
}
return false;
}
telephoneCheck("555-555-5555");
[Advanced Algorithm] - Validate US Telephone Numbers的更多相关文章
- FCC高级编程篇之Validate US Telephone Numbers
Validate US Telephone Numbers Return true if the passed string is a valid US phone number. The user ...
- Validate US Telephone Numbers
function telephoneCheck(str) { // Good luck! //return true; var phone = /^1? ?(\d{3}|\(\d{3}\))[ -]? ...
- FCC(ES6写法) Validate US Telephone Numbers
如果传入字符串是一个有效的美国电话号码,则返回 true. 思路:用正则,参考网上资料和js高级程序设计(5.4RegExp类型). let telephoneCheck = str => /^ ...
- Validate US Telephone Numbers FreeCodeCamp
function telephoneCheck(str) { // 祝你好运 //var re = /^1? ?(\(\d{3}\)|\d{3})[ |-]?\d{3}[ |-]?\d{4}$/; / ...
- PAT (Advanced Level) Practice 1120 Friend Numbers (20 分) (set)
Two integers are called "friend numbers" if they share the same sum of their digits, and t ...
- PAT Advanced 1023 Have Fun with Numbers (20) [⼤整数运算]
题目 Notice that the number 123456789 is a 9-digit number consisting exactly the numbers from 1 to 9, ...
- Educational Codeforces Round 63 (Rated for Div. 2) B. Game with Telephone Numbers 博弈思维+模拟+贪心思维
题意:博弈题面 给出一个数字序列 (>=11) 有两个人任意删除数字 直到 数字只剩下11位 如果删除后的数字串开头是8那么就是第一个赢 否则就是第二个人赢 第一个人先手 数字序列一定是奇 ...
- 高级算法设计讲义 Lecture Notes for Advanced Algorithm Design
(Last modification: 2012-12-17) Textbooks: (1) David Williamson, David Shmoys. The Design of Approxi ...
- [Advanced Algorithm] - Inventory Update
题目 依照一个存着新进货物的二维数组,更新存着现有库存(在 arr1 中)的二维数组. 如果货物已存在则更新数量 . 如果没有对应货物则把其加入到数组中,更新最新的数量. 返回当前的库存数组,且按货物 ...
随机推荐
- noip模拟赛 希望
分析:题目中说用栈实现,我觉得这样很麻烦,就用了一个数组+指针解决了.其实就是大模拟. #include <stack> #include <string> #include ...
- nyoj 307
/*这是一道最短路变形题 从每个有藏宝的地方为起点 求到各个点的可以的最大重量,相当于求出了从出口 到 一个藏宝点 所 允许的最大重量,把所有藏宝点的按重量 排序(从小到大)先到最小的藏宝点带上 宝 ...
- 大逃亡(escape.*)
给出数字N(1<=N<=10000),X(1<=x<=1000),Y(1<=Y<=1000),代表有N个敌人分布一个X行Y列的矩阵上,矩形的行号从0到X-1,列号从 ...
- nyoj_71_独木舟上的旅行_201312122051
独木舟上的旅行 时间限制:3000 ms | 内存限制:65535 KB 难度:2 描述 进行一次独木舟的旅行活动,独木舟可以在港口租到,并且之间没有区别.一条独木舟最多只能 ...
- CF #330 C
改了题目之后,就是没有奇数的测试了... 其实可以很轻易地发现,要距离近的一方只会删除两端的,而要求远的一方会删除中间的. 那么,很明显的,剩下的两点会相差x/2个节点,于是,只要计算i和i+x/2的 ...
- 使用Win32 API实现生产者消费者线程同步
使用win32 API创建线程,创建信号量用于线程的同步 创建信号量 语法例如以下 HANDLE semophore; semophore = CreateSemaphore(lpSemaphoreA ...
- HDU 5387 Clock (MUT#8 模拟)
[题目链接]:pid=5387">click here~~ [题目大意]给定一个时间点.求时针和分针夹角,时针和秒针夹角,分针和秒针夹角 模拟题,注意细节 代码: #include&l ...
- Swift代理和传值
第一个视图控制器: import UIKit // 遵循协议 class ViewController: UIViewController,SecondVCDelegate { override fu ...
- C语言里全局变量管理
C语言里信息封装比較弱,仅仅有静态变量的文件作用域. 假设不加约束.非常easy造成全局变量满天飞. 假设定义一个全局结构体.把全局变量都放到这个GlobleVariate里,应该好管一些,至少比裸奔 ...
- Mahout算法调用展示平台2.1
软件版本号: windows7: Tomcat7.JDK7.Spring4.0.2.Struts2.3.Hibernate4.3.myeclipse10.0.easyui:Linux(centos6. ...