描述:正则问题
考虑一种简单的正则表达式:
只由 x ( ) | 组成的正则表达式。
小明想求出这个正则表达式能接受的最长字符串的长度。
例如 ((xx|xxx)x|(x|xx))xx 能接受的最长字符串是: xxxxxx,长度是6。
输入
----
一个由x()|组成的正则表达式。输入长度不超过100,保证合法。
输出
----
这个正则表达式能接受的最长字符串的长度。
例如,
输入:
((xx|xxx)x|(x|xx))xx
程序应该输出:
6
资源约定:
峰值内存消耗(含虚拟机) < 256M
考虑一种简单的正则表达式:
只由 x ( ) | 组成的正则表达式。
小明想求出这个正则表达式能接受的最长字符串的长度。
例如 ((xx|xxx)x|(x|xx))xx 能接受的最长字符串是: xxxxxx,长度是6。
输入
----
一个由x()|组成的正则表达式。输入长度不超过100,保证合法。
输出
----
这个正则表达式能接受的最长字符串的长度。
例如,
输入:
((xx|xxx)x|(x|xx))xx
程序应该输出:
6
资源约定:
峰值内存消耗(含虚拟机) < 256M
CPU消耗 < 1000ms
import java.util.Scanner;
public class Test2017_7 {
static int res = 0;
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner scan = new Scanner(System.in);
String s = scan.next();
fun(s);
System.out.println(res);
}
static void fun(String s){
int left = 0,right = 0,mid = 0;
for(int i=0;i<s.length();i++){
String temp = s.substring(i,i+1);
if(temp.equals("(")){
left = i;
}
else if(temp.equals("|")){
mid = i;
}
else if(temp.equals(")")){
right = i;
break;
}
}
System.out.println(right+s);
if(mid!=0){
int right1,left1;
right1 = right;
left1 = left;
if(right==0){
right = s.length()-1;
left1 = left - 1;
right1 = right + 1;
}
String s1 = s.substring(left,right+1);
String s2 = "";
if(mid-left>=right-mid){
s2 = s.substring(left1+1,mid);
}
else{
s2 = s.substring(mid+1, right1);
}
s = s.replace(s1, s2);
fun(s);
}
else{
if(right==0){
res = s.length();
}
else{
String s1 = s.substring(left,right+1);
String s2 = s.substring(left+1,right);
s = s.replace(s1, s2);
fun(s);
}
}
}
}
从左往右查询,left代表左括号"(",right代表右括号")",mid代表竖杠"|"
将最内的一对括号取出为s1,取出"|"两旁更长的字符串s2,将字符串中的s1替换为s2,递归进行下一步。
分别需要细心考虑的各种情况,包括类似于"(xxx)"、"x|xx"、"(xx|x)";
最后得到只有"x"的字符串,长度即为答案。