java必刷题——正则表达式
作者:互联网
题目
需求分析
解题思路
- 获取用户输入的 需矫正字符总数;
- 根据用户输入的 总数 对错误字符进行矫正;
技术栈
java正则表达式
代码实现
package OpenClosedPrinciple;
import java.util.Scanner;
/**
* ClassName: OpenCloseTest <br/>
* Description: <br/>
* date: 2021/6/19 20:56<br/>
*
* @author yiqi<br />
* @since JDK 1.8
*/
public class OpenCloseTest {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
//1、获取用户输入的 需矫正字符 总数
int num = scanner.nextInt();
//2、根据用户输入的 总数 对错误字符进行矫正
for (int i=0; i< num; i++){
String inValue = scanner.next();
String retValue = inValue.replaceAll("(.)\\1+","$1$1").replaceAll("(.)\\1(.)\\2","$1$1$2");
System.out.println(retValue);
}
}
}
代码思路很简单,唯一难点是这个正则表达式,下面我就为大家简单介绍一下,java中正则表达式的含义:
"(.)\\1+","$1$1":
- . 表示匹配所有字符
- ()表示捕获匹配字符
- 第一个 \ 表示转义 于是 大家最后看到的结果是 \1,那这个 \1 表示 \1 所在位置的字符和第一个(.)匹配的字符相同,例如:AA 就会被匹配上。即第一个A对应(.),第二个A对应 \1
- $1 表示用 第一个(.)匹配的字符来替换所匹配到的字符
大家把 正则表达式 理解了,后面可就太简单了
标签:矫正,字符,java,Scanner,正则表达式,必刷题,匹配 来源: https://blog.csdn.net/qq_41885673/article/details/118255238