zoukankan      html  css  js  c++  java
  • Java实现第八届蓝桥杯正则问题

    正则问题

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

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

    输入

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

    输出

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

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

    程序应该输出:
    6

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

    请严格按要求输出,不要画蛇添足地打印类似:“请您输入…” 的多余内容。

    所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。
    不要使用package语句。不要使用jdk1.7及以上版本的特性。
    主类的名字必须是:Main,否则按无效代码处理。

    PS:
    本题栈的基础应用 思路很简单 ‘(’ ‘x’ ‘|’ 入栈 碰见‘)’然后出栈
    出栈的时候 把他们连一起 然后用‘|’进行切割 模拟或运算
    留下最长的那个字符串 入栈 最后所有的东西都出栈
    在进行上面的操作 不过本题比较坑 括号有不是成对的 吐槽一下 什么破语法

    第二个有点问题,错误的我建议也看看,省的下次犯

    import java.util.Scanner;
    
    public class 正则问题 {
    	static int count;
    	static char[] a = new char[200];
    	static int p;
    	static int max =-1;;
    
    	public static void main(String[] args) {
    		Scanner in = new Scanner(System.in);
    		a = in.next().toCharArray();
    		dfs();
    		System.out.println(max);
    	}
    
    	static int dfs() {
    		int xnum = 0;
    		int maxx = 0;
    
    		while (p < a.length) {
    			max=Math.max(xnum, max);
    			max=Math.max(maxx, max);
    			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=Math.max(xnum, maxx);
    //				max=Math.max(maxx, max);
    				//maxx = Math.max(xnum, maxx);
    				xnum = 0;
    			}
    			max=Math.max(xnum, max);
    //			max=Math.max(maxx, max);
    		}
    		return Math.max(xnum, maxx);
    	}
    }
    
    
    import java.io.File;
    import java.io.FileNotFoundException;
    import java.text.ParseException;
    import java.util.Scanner;
    
    /**
     
     * 采用DFS,从前到后遍历遇到(就开始新的搜索,遇到)则停止搜索并通过比较,找出这个括号里的最大值;
     * 如果遇到|,则需要记录之前的长度,用于在之后)的比较。遇到x,长度加一,且继续往下找
     * 
      每一个()都是一次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);
    	}
    }
    
    
  • 相关阅读:
    程序员丨学习编程需要攻克这 8 个壁垒,解决后编程能力显著提升!
    编程不难学,方法最重要!学习编程语言最好的方法是什么?
    Navicat for MySQL怎么往表中填数据
    WinForm开发(1)——DataGridView控件(1)——C# DataGridView控件用法介绍
    【C#】图解如何添加引用using MySql.Data.MySqlClient;
    源代码管理工具(2)——SVN(2)——第一次用SVN遇到的问题
    源代码管理工具(1)——SVN(1)——SVN 的使用新手指南,具体到步骤详细介绍----TortoiseSVN
    C#取整函数Math.Round、Math.Ceiling和Math.Floor
    服务器(2)——IIS(2)——IIS Express(1)——IIS跟IIS Express之间的区别和关系
    C# 连接 Oracle 的几种方式
  • 原文地址:https://www.cnblogs.com/a1439775520/p/13077441.html
Copyright © 2011-2022 走看看