第1关:练习-Java字符串之正则表达式之匹配手机号码
任务描述
本关任务:接收给定的字符串,判断字符串中的数字是否为手机号码。 三大运营商手机号码所有号段如下: 中国电信号段:133、149、153、173、177、180、181、189
。 中国联通号段:130、131、132、145、155、156、166、175、176、185、186
。 中国移动号段:134、135、136、137、138、139、147、150、151、152、157、158、159、178、182、183、184、187、188
。
编程要求
仔细阅读右侧编辑区内给出的代码框架及注释,按照提示编写程序代码。
测试说明
平台将使用测试集运行你编写的程序代码,若全部的运行结果正确,则通关。
可在右侧 “测试结果”区查看具体的测试集详情。 例: 测试输入:
13500329876@sdsdsda
预期输出
13500329876是手机号码
开始你的任务吧,祝你成功!
源代码:
/*
任务:接受给定的字符串,判断该字符串中的数字是否为手机号码。
字符串样式:34343@sdeff(@之前为数字,之后为英文字母)。
正则表达式思路:手机号码的前三位为特定号码段,后8位为任意数字。
*/
import java.util.Scanner;
public class StrTest {
public static void main(String[] args) {
// 请在Begin-End间编写代码
/********** Begin **********/
// 接收给定的字符串
Scanner input = new Scanner(System.in);
String str = input.next();
// 分割字符串
String[] array = str.split("@");
// 判断给定字符串中的数字是否属于手机号码,是的话请输出:“X是手机号码”
int length = array[0].length();//位数
boolean b1 = array[0].matches("^1[3|8][0-9]+$");
boolean b2 = array[0].matches("^14[5|7|9][0-9]+$");
boolean b3 = array[0].matches("^15[0-3|5-9][0-9]+$");
boolean b4 = array[0].matches("^166[0-9]+$");
boolean b5 = array[0].matches("^17[3|5-8][0-9]+$");
if (length == 11 & (b1 == true | b2 == true | b3 == true | b4 == true | b5 == true)){
System.out.println(array[0] + "是手机号码");
// 不符合的话请输出:“X是不手机号码”
}else {
System.out.println(array[0] + "不是手机号码");
}
/********** End **********/
}
}