任务描述
本关任务:接收给定的字符串,如果该字符串同时符合以下要求,请输出该字符串。 1.字符串由三个字符组成; 2.字符串以数字开头; 3.字符串以小写字母结束。
相关知识
正则表达式的概念
正则表达式,又称规则表达式,计算机科学的一个概念。正则表达式通常被用来检索、替换那些符合某个模式(规则)的文本。
我们可以使用正则表达式^\d+b$可以匹配到如下所有字符串:
23sb、32run4oob、2oo32ooob
其中正则表达式中的\d属于正则表达式中的元字符,代表 0-9 中的任意一个数字。+、^和$属于正则表达式中的限定修饰符,+代表一个或者多个,^代表开始位置,$代表结束位置。所以该正则表达式中可以匹配到以数字开头,以字母 b 结尾的所有字符串。 #####正则表达式中的元字符
| 元字符 | 正则表达式中的写法 | 意义 |
|---|---|---|
| . | . | 代表任意一个字符 |
| \d | \d | 代表0-9的任何一个数字 |
| \D | \D | 代表任何一个非数字字符 |
| \s | \s | 代表空白字符,如‘\t’,'\n' |
| \S | \S | 代表非空白字符 |
| ^ | ^ | 匹配字符串的开始 |
| $ | $ | 匹配字符串的结束 |
| x|y | x|y | 匹配 x 或 y。例如,'z|food' 能匹配 "z" 或 "food"。'(z|f)ood' 则匹配 "zood" 或 "food" |
| [xyz] | [xyz] | 字符集合。匹配所包含的任意一个字符。例如, '[abc]' 可以匹配 "plain" 中的 'a' |
| [a-z] | [a-z] | 字符范围,匹配指定范围内的任意字符。例如,'[a-z]' 可以匹配 'a' 到 'z' 范围内的任意小写字母字符 |
| [^a-z] | [^a-z] | 负值字符范围,匹配任何不在指定范围内的任意字符。例如,'[^a-z]' 可以匹配任何不在 'a' 到 'z' 范围内的任意字符 |
| \w | \w | 匹配字母、数字、下划线。等价于'[A-Za-z0-9_]' |
| \W | \W | 匹配非字母、数字、下划线。等价于 '[^A-Za-z0-9_]' |
String 类中正则表达式的应用
1.matches() 方法:判断字符串是否匹配正则表达式。
String str="8sA";boolean matches = str.matches("\\d[a-z][A-Z]"); // 判断字符串是否匹配正则表达式,其中代表任意数字的\d用在代码中需要使用转义符\。System.out.println(matches);
执行结果:
true
2.split() 方法:根据正则表达式切割字符串。
String str="sA-sA";// 根据正则表达式切割字符串String[] split = str.split("-");System.out.print(split);
执行结果:
[sA,sA]
3.replaceAll() 方法:替换符合正则表达式的字符串内容。
String str="sA-sA";// 替换符合正则表达式的字符串内容String s = str.replaceAll("[a-z]", "123");System.out.print(s);
执行结果:
123A-123Aimport 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(); // 第二步:判断给定的字符串是否符合给定的规则,符合的话请输出该字符串 int length = str.length(); boolean matches = str.matches("^\\d+[a-z]+$"); if (length == 3 && matches == true){ System.out.println(str); // 第三步:不符合的话请输出该字符串不符合规则 }else { System.out.println(str + "不符合给定规则"); } /********** End **********/ } }
版权声明:本文为weixin_46075438原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。