Java中的String类下的正则表达式运用附带编程题解析

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java中的String类下的正则表达式运用附带编程题解析相关的知识,希望对你有一定的参考价值。

以下是我做牛客网题时,遇到的使用正则表达式可以简单化代码,所以我们需要掌握这两个知识点,方便解决以后遇到类似的问题。

1. public String replaceAll(String regex,String replacement)
使用给定的 replacement 字符串替换此字符串匹配给定的正则表达式的每个子字符串**
replaceAll的参数是regex,即基于正则表达式的替换,比如,可以通过replaceAll("d", "")把一个字符串所有的数字字符都换成
如果只想替换第一次出现的,可以使用replaceFirst(),这个方法也是基于规则表达式的替换,但与replaceAll()不同的是,只替换第一次出现的字符串;

另外,如果replaceAll()和replaceFirst()所用的参数据不是基于规则表达式的,则与replace()替换字符串的效果是一样的,即这两者也支持字符串的操作;
2,publilc boolean matches(String regex):
matches() 方法用于检测字符串是否匹配给定的正则表达式。

```
Pattern.matches(regex, str)
public boolean matches(String regex)

参数:regex – 匹配字符串的正则表达式。//(.)...(.)或者【】
两种表达式产生的结果完全相同
``

public class Demo1 {
//代码示例

public static void main(String[] args){

    String Str = new String("我是一只小小鸟");

    System.out.println("返回值 :"+Str.matches("(.*)一只(.*)"));

    boolean flag = Str.matches("我是(.*)");
    if(flag){
        System.out.println("我被重新定义为:HelloWord!");
    }else{
        System.out.println("我没有被重新定义!");
    }
}

}
执行jie‘gu
返回值 :true
我被重新定义为:HelloWord!


********(编程题)
开发一个坐标计算工具, A表示向左移动,D表示向右移动,W表示向上
移动,S表示向下移动。从(0,0)点开始移动,从输入字符串里面读取
一些坐标,并将最终输入结果输出到输出文件里面。

输入:
合法坐标为A(或者D或者W或者S) + 数字(两位以内)
坐标之间以;分隔。非法坐标点需要进行丢弃。如AA10;  A1A;  $%$;  YAD; 等。
下面是一个简单的例子 如:
10;S20;W10;D30;X;A1A;B10A11;;A10;
处理过程:
起点(0,0)
+   A10   =  (-10,0)
+   S20   =  (-10,-20)
+   W10  =  (-10,-10)
+   D30  =  (20,-10)
+   x    =  无效
+   A1A   =  无效
+   B10A11   =  无效
+  一个空 不影响
+   A10  =  (10,-10)
结果 (10, -10)
注意请处理多组输入输出**

import java.util.*;
public class Main{
 public static void main(String[] args){
Scanner sc=new Scanner(System.in);
 while(sc.hasNext()){
 String str=sc.nextLine();
 String[] A=str.split(";");
 int x=0,y=0;
 for(String string:A){
 if(string.charAt(0)==‘D‘ && string.substring(1).matches("[0-9]+"))
 //  +   的意思是匹配一次或者多次,可以是9.99.999.。。。
 x+=Integer.parseInt(string.substring(1));

 if(string.charAt(0)==‘W‘ && string.substring(1).matches("[0-9]+"))
 y+=Integer.parseInt(string.substring(1));

 if(string.charAt(0)==‘S‘ && string.substring(1).matches("[0-9]+"))
y-=Integer.parseInt(string.substring(1));

 if(string.charAt(0)==‘A‘ && string.substring(1).matches("[0-9]+"))
 x-=Integer.parseInt(string.substring(1));

 }
System.out.println(x+","+y);
 }

 sc.close();
 }

}

经常碰到的编程题:
删除公共字符
****# > *输入两个字符串,从第一字符串中删除第二个字符串
# > 中所有的字符。例如,输入”They are students.”和”aeiou”,
# > 则删除之后的第一个字符串变成”Thy r stdnts.”***
import java.util.Scanner;
public class DeleteChar {
    public static void main(String[] args) {
        Scanner scanner=new Scanner(System.in);
        while (scanner.hasNext()){
            String src=scanner.nextLine();
            String dest=scanner.nextLine();
           String patten="["+dest+"]";//正则表达式的规则形式
           String result=src.replaceAll(patten,"");//src是不变的
                     //用空串去替代出现在src中的patten(以及patten的任意一个字串)
            System.out.println(result);

        }

    }
}

以上是关于Java中的String类下的正则表达式运用附带编程题解析的主要内容,如果未能解决你的问题,请参考以下文章

JDK6和JDK7中String类下的substring方法的代码对比(仅贴代码,未详述)

关于java Collections类下的sort方法的一个问题 /麻烦解释一下输出结果,sort是怎么进行排序的?

java中怎么替换string中的某个字符

Java正则表达式提取String字符串中的IP地址

如何在 Java 中的 String.contains() 方法中使用正则表达式

java正则表达式