当前位置: 首页 > backend >正文

头歌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
开始你的任务吧,祝你成功!

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 **********/}
}

http://www.xdnf.cn/news/10296.html

相关文章:

  • 每日c/c++题 备战蓝桥杯(P1204 [USACO1.2] 挤牛奶 Milking Cows)
  • [蓝桥杯]分考场
  • 【11408学习记录】考研英语写作提分秘籍:2013真题邀请信精讲+万能模板套用技巧
  • 1-Wire 一线式总线:从原理到实战,玩转 DS18B20 温度采集
  • AE已禁用刷新请释放Caps Lock
  • Redis事务详解:原理、使用与注意事项
  • RabbitMQ 高级特性
  • Python打卡训练营Day41
  • C 语言开发中常见的开发环境
  • python打卡day41@浙大疏锦行
  • 【愚公系列】《生产线数字化设计与仿真》006-颜色分类站仿真(配置颜色分类站的气缸和传送带)
  • YOLO系列中的C3模块解析2025.5.31
  • 《重新定义高效微调:QLoRA 4位量化的颠覆式创新解析》
  • 数字化转型进阶:精读41页华为数字化转型实践【附全文阅读】
  • 在Spring Boot中集成Redis进行缓存
  • 赛博算命之“帝王之术”——奇门遁甲的JAVA实现
  • Dest建筑能耗模拟仿真功能简介
  • 业界宽松内存模型的不统一而导致的软件问题, gcc, linux kernel, JVM
  • 流媒体基础解析:视频清晰度的关键因素
  • 深度学习|pytorch基本运算-广播失效
  • 方案精读:42页华为企业组织活力设计方案【附全文阅读】
  • 什么是trace,分布式链路追踪(Distributed Tracing)
  • C++ 建造者模式:简单易懂的设计模式解析
  • 保持本地 Git 项目副本与远程仓库完全同步
  • LeetCode 每日一题 2025/5/26-2025/6/1
  • DO指数GPU版本
  • Redis最佳实践——安全与稳定性保障之高可用架构详解
  • 双目相机深度的误差分析(基线长度和相机焦距的选择)
  • python中将一个列表样式的字符串转换成真正列表的办法以及json.dumps()和 json.loads()
  • 谷歌工作自动化——仙盟大衍灵机——仙盟创梦IDE