编程语言
首页 > 编程语言> > java必刷题——正则表达式

java必刷题——正则表达式

作者:互联网

题目

需求分析

 解题思路

  1. 获取用户输入的 需矫正字符总数;
  2. 根据用户输入的 总数 对错误字符进行矫正;

技术栈

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