2017第八届蓝桥杯省赛Java A组--正则问题

版权声明:转载请注明出处 https://blog.csdn.net/xuyangxinlei/article/details/79669892
描述:正则问题

考虑一种简单的正则表达式:
只由 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"的字符串,长度即为答案。

猜你喜欢

转载自blog.csdn.net/xuyangxinlei/article/details/79669892