头歌java课程实验(学习-Java字符串之正则表达式之元字符之判断字符串是否符合规则)

第1关:学习-Java字符串之正则表达式之元字符之判断字符串是否符合规则

任务描述

本关任务:接收给定的字符串,如果该字符串同时符合以下要求,请输出该字符串。

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-123A

编程要求

仔细阅读右侧编辑区内给出的代码框架及注释,按照提示编写程序代码。

测试说明

平台将使用测试集运行你编写的程序代码,若全部的运行结果正确,则通关。

可在右侧 "测试结果"区查看具体的测试集详情。

例:

测试输入:

sssss9098djhshduew

预期输出

sssss9098djhshduew不符合给定规则

测试输入:

0ww

预期输出

0ww

开始你的任务吧,祝你成功!

java 复制代码
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();
// 第二步:判断给定的字符串是否符合给定的规则,符合的话请输出该字符串
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 **********/
 
    }
}
相关推荐
lee_curry40 分钟前
第四章 jvm中的垃圾回收器
java·jvm·垃圾收集器
酿情师2 小时前
yihan:一款面向连续网页学习的智能侧边栏插件
学习·学习方法·工具·学习工具
九转成圣2 小时前
Java 性能优化实战:如何将海量扁平数据高效转化为类目字典树?
java·开发语言·json
直奔標竿2 小时前
Java开发者AI转型第二十七课!Spring AI 个人知识库实战(六)——全栈闭环收官,解锁前端流式渲染终极技巧
java·开发语言·前端·人工智能·后端·spring
瞎某某Blinder2 小时前
DFT学习记录[6]基于 HES06的能带计算+有效质量计算
python·学习·程序人生·数据挖掘·云计算·学习方法
金銀銅鐵3 小时前
[java] 编译之后的记录类(Record Classes)长什么样子(上)
java·jvm·后端
love在水一方4 小时前
VLN 入门学习计划 —— 基于 InternNav
学习
野生技术架构师4 小时前
金三银四面试总结篇,汇总 Java 面试突击班后的面试小册
java·面试·职场和发展
小袁拒绝摆烂5 小时前
多表关联大平层转JSON树形结构
java·json