题目

如果传入字符串是一个有效的美国电话号码,则返回 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.

提示

RegExp

测试用例

  • 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)") 应该返回 false
  • telephoneCheck("2 (757) 622-7382") 应该返回 false.
  • telephoneCheck("0 (757) 622-7382") 应该返回 false.
  • telephoneCheck("-1 (757) 622-7382") 应该返回 false
  • telephoneCheck("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. 分析该题,主要是分析电话号码的有效排列方式,有效的号码规则如下:
  • 分离 国家码-区号-电话号,格式如 1-555-555-5555,其中每个分段中间是不能被分割的,如1-55-5-555-5555是非法的;
  • 在不能分段的每个区域中和两头,空格是可以随意加的(任意个),如: 1 555 555 5555155555555555是合法的;
  • 在不能分段的每个区域中,中划线是可以加一个的,如:1-555-555-5555 1 - 555-555 - 55551 - 555-5555555是合法的,1-555--555-5555是非法的;
  • 在区号上可以加小括号,而且必须配对,括号中间允许出现空格在数字两边,如:1(555)555 55551( 555 )5555555是合法的,1 555) 555 5555是非法的;
  • 除了以上分隔符和数字,其他任意符号都是非法的,如:1a(555)555 55551(555) 555 5555$都是非法的;
  • 数字必须限制在 10 个(无国家码)/11个,如:1 555 5555 5555是非法的;
  • 国家码可以不存在,存在则必须为1,如:(555) 555 55551 555 555 5555是合法的,而2 555 555 5555是非法的;
  1. 正则表达式编写
  • 数字分段匹配,[\d]{3}这样就是匹配连续三个数字,通过该方式,可以匹配数字分段和数字数目;
  • ? 匹配符,匹配一个或0个前面的符号,如:[-]?,匹配一个或0个中划线;
  • * 匹配符,匹配0个或多个前面的符号,如:[\s]*,匹配0个或多个空格;
  • ^$ 两个符号分别表示字符串首匹配和字符串尾匹配,两个均加入表示从串首匹配到串尾,如:^[\d]{3}[-][\d]{3}-[\d]{4}$这个正则式,555-555-5555是匹配的,但a55-555-5555555-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的更多相关文章

  1. FCC高级编程篇之Validate US Telephone Numbers

    Validate US Telephone Numbers Return true if the passed string is a valid US phone number. The user ...

  2. Validate US Telephone Numbers

    function telephoneCheck(str) { // Good luck! //return true; var phone = /^1? ?(\d{3}|\(\d{3}\))[ -]? ...

  3. FCC(ES6写法) Validate US Telephone Numbers

    如果传入字符串是一个有效的美国电话号码,则返回 true. 思路:用正则,参考网上资料和js高级程序设计(5.4RegExp类型). let telephoneCheck = str => /^ ...

  4. Validate US Telephone Numbers FreeCodeCamp

    function telephoneCheck(str) { // 祝你好运 //var re = /^1? ?(\(\d{3}\)|\d{3})[ |-]?\d{3}[ |-]?\d{4}$/; / ...

  5. 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 ...

  6. 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, ...

  7. Educational Codeforces Round 63 (Rated for Div. 2) B. Game with Telephone Numbers 博弈思维+模拟+贪心思维

    题意:博弈题面  给出一个数字序列 (>=11)  有两个人任意删除数字 直到 数字只剩下11位 如果删除后的数字串开头是8那么就是第一个赢 否则就是第二个人赢 第一个人先手  数字序列一定是奇 ...

  8. 高级算法设计讲义 Lecture Notes for Advanced Algorithm Design

    (Last modification: 2012-12-17) Textbooks: (1) David Williamson, David Shmoys. The Design of Approxi ...

  9. [Advanced Algorithm] - Inventory Update

    题目 依照一个存着新进货物的二维数组,更新存着现有库存(在 arr1 中)的二维数组. 如果货物已存在则更新数量 . 如果没有对应货物则把其加入到数组中,更新最新的数量. 返回当前的库存数组,且按货物 ...

随机推荐

  1. bupt summer training for 16 #4 ——数论

    https://vjudge.net/contest/173277#overview A.平方差公式后变为 n = (x + y)(x - y) 令 t = x - y ,变成 n = (t + 2x ...

  2. 清北学堂模拟赛d5t5 exLCS

    分析:比较巧妙的一道题.经典的LCS算法复杂度是O(nm)的,理论上没有比这个复杂度更低的算法,除非题目有一些限制.这道题中两个字符串的长度不一样,f[i][j]如果表示第一个串前i个,第二个串前j个 ...

  3. POJ 3304 segments 线段和直线相交

    Segments Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 14178   Accepted: 4521 Descrip ...

  4. spring mvc dispatcherservlet处理request流程

    1.dispatcherservlet接收到请求后,doDispatch(request,response) 2.doDispatch()里进行handlermapping,handlermappin ...

  5. HDU 5226

    公式啊,公式啊....TAT 杭电题解.....高中生...... 对于卢卡斯定理,由于p较大,所以不可能按一般的来算,n,m较小,循处理出n!的逆元对p的,然后可以按照卢卡斯定理,降低,对后面的就可 ...

  6. hdu1316(大数的斐波那契数)

    题目信息:求两个大数之间的斐波那契数的个数(C++/JAVA) pid=1316">http://acm.hdu.edu.cn/showproblem.php? pid=1316 这里 ...

  7. 【SDOI2008】【BZOJ2049】Cave 洞穴勘測

    Description 辉辉热衷于洞穴勘測.某天,他依照地图来到了一片被标记为JSZX的洞穴群地区.经过初步勘測,辉辉发现这片区域由n个洞穴(分别编号为1到n)以及若干通道组成.而且每条通道连接了恰好 ...

  8. android 自己定义ViewGroup实现可记载并呈现选择的ListView

    转载请注明出处:王亟亟的大牛之路 之前也做过一些用TextView之类的记录ListView选项的东西.可是总认为好难看.发现个不错的实现就贴给大家. 项目文件夹 执行效果: 自己定义视图: @Tar ...

  9. hdu 4932 Miaomiao's Geometry(暴力枚举)

    pid=4932">Miaomiao's Geometry                                                               ...

  10. yum install mysql(转载)

    linux下使用yum安装mysql 1.安装查看有没有安装过:          yum list installed mysql*          rpm -qa | grep mysql* 查 ...