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

描述:正则问题

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

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值