第八届蓝桥杯 JavaA 正则问题

第八届蓝桥杯 JavaA 正则问题


描述:正则问题

考虑一种简单的正则表达式:
只由 x ( ) | 组成的正则表达式。
小明想求出这个正则表达式能接受的最长字符串的长度。

例如 ((xx|xxx)x|(x|xx))xx 能接受的最长字符串是: xxxxxx,长度是6。

输入

一个由x()|组成的正则表达式。输入长度不超过100,保证合法。

输出

这个正则表达式能接受的最长字符串的长度。

例如,
输入:
((xx|xxx)x|(x|xx))xx

程序应该输出:
6

资源约定:
峰值内存消耗(含虚拟机) < 256M
CPU消耗 < 1000ms

((xx|xx)x|(x|x))xx 5


法一:
思路:
* 采用DFS,从前到后遍历遇到(就开始新的搜索,遇到)则停止搜索并通过比较,找出这个括号里的最大值;
* 如果遇到|,则需要记录之前的长度,用于在之后)的比较。遇到x,长度加一,且继续往下找
import java.io.File;
import java.io.FileNotFoundException;
import java.text.ParseException;
import java.util.Scanner;

/**
 * https://blog.csdn.net/qq_34243930/article/details/79604366
 * https://blog.csdn.net/pk__pk/article/details/79650128
 * 采用DFS,从前到后遍历遇到(就开始新的搜索,遇到)则停止搜索并通过比较,找出这个括号里的最大值;
 * 如果遇到|,则需要记录之前的长度,用于在之后)的比较。遇到x,长度加一,且继续往下找
 * 
 * @description TODO
 * @author frontier
 * @time 2019年3月23日 下午2:17:54 每一个()都是一次dfs,可返回期间最大x数量
 */
public class 编程7正则问题 {
	// static Scanner in = new Scanner(System.in);
	static int count;
	static char[] a = new char[200];
	static int p;

	public static void main(String[] args) throws ParseException, FileNotFoundException {
		Scanner in = new Scanner(new File("src/JavaA/s8/7.txt"));
		a = in.next().toCharArray();
		System.out.println(dfs());
	}

	static int dfs() {
		int xnum = 0;
		int maxx = 0;

		while (p < a.length) {
			if (a[p] == 'x') {
				p++;
				xnum++;
			} else if (a[p] == '(') {
				p++;
				xnum += dfs();
			} else if (a[p] == ')') {
				p++;
				break;
			} else if (a[p] == '|') {
				p++;
				maxx=xnum;
				//maxx = Math.max(xnum, maxx);
				xnum = 0;
			}
		}
		return Math.max(xnum, maxx);
	}
}

你可能感兴趣的:(第八届蓝桥杯 JavaA 正则问题)