2017蓝桥杯省赛---java---A---7(正则问题)

题目描述

考虑一种简单的正则表达式:
只由 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,否则按无效代码处理。

思路分析

在这里插入图片描述

在这里插入图片描述

代码实现

package TEST;import java.util.Scanner;
class Main{public static int len;public static int pos;public static String s;public static void main(String[] args) {Scanner scanner = new Scanner(System.in);s=scanner.nextLine();len=s.length();int ans=f();System.out.println(ans);scanner.close();}/*求出当前字符串,自当前下标到结束能匹配的字符串的长度*/public static int f(){int ans=0;int temp=0;//用于保存连续的x的数量while (pos<len){if(s.charAt(pos)=='('){pos++;temp+=f();//等待后面的结果并累加到ans}else if(s.charAt(pos)=='x'){pos++;temp++;}else if(s.charAt(pos)=='|'){pos++;ans=Math.max(ans,temp);temp=0;}else if (s.charAt(pos)==')'){pos++;return Math.max(ans,temp);}}return Math.max(ans,temp);}
}

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/326204.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HTML表单元素

表单一、表单的语法&#xff1a; 1.提交方式&#xff1a; get:不安全&#xff0c;地址栏里面有提交内容 post:相对安全&#xff0c;地址栏里面不显示提交的内容 2.提交按钮&#xff1a;submit 3.重置按钮&#xff1a;reset 4.input中常用的属性&#xff1a; 1)type&#xf…

android 设置视频音量大小,为cocos2d-x添加调节视频音量的功能(Android)

为cocos2d-x添加调节视频音量的功能(Android)。日常吐槽cocos。我想放广告的时候播放一些其他声音&#xff0c;这时候我希望视频先静音&#xff0c;但是不停止播放。等声音播放完&#xff0c;我再放视频声音。赫然发现&#xff0c;VideoPlayer 居然没这个接口。而且现在视频的播…

Mybatis简介与原理

转载自 Mybatis简介与原理 什么是Mybatis MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code&#xff0c;并且改名为MyBatis 。iBATIS一词来源于“internet”和“abatis”的组合&#xff0c;是一个基于Java的持久层框…

JavaWeb前端之AJAX的初步学习

l AJAX的优点&#xff1a; 1、 最大的一点是页面没有刷新&#xff0c;在页面内与服务器通讯&#xff0c;给用户的体验非常好。 2、 使用异步的方式与服务器通讯&#xff0c;不需要打断用户的操作&#xff0c;具有更加速度的响应能力。 3、 可以…

Visual Studio 2017通过SSH支持Git

在大多数开发人员的工具包中&#xff0c;Git的重要性在不断提升&#xff0c;说它是一项必备技能也不为过&#xff0c;所以对于任意一款现代化的IDE来说&#xff0c;能够使用Git多样化的功能都是其重要的组成部分。在Visual Studio 2017中&#xff0c;微软已经在其UI界面中扩展了…

HTML列表、表格和媒体元素

列表、表格和媒体元素 一、列表&#xff1a;信息资源的一种展示形式 二、列表的分类&#xff1a;有序列表1.例子&#xff1a;<ol><li>内容</li></ol>2.特性&#xff1a;有顺序&#xff0c;每个li都是块级元素默认的li前面有顺序标记无序列表1.例子&…

2018蓝桥杯省赛---java---A---1(分数)

题目描述 思路分析 方案一 等比数列&#xff0c;再进行约分 方案二 求和 约分&#xff1a;辗转相除法求最大公约数 package TEST;class Main{static int GCD(int x,int y){//求最大公约数if(y0){return x;}return GCD(y,x%y);//是x%y&#xff0c;不是x/y}public static vo…

Android微信分享之微信项目注册与申请

Android微信开发 第一步&#xff1a;在微信开放平台注册账号以及申请项目&#xff1a; 创建应用&#xff0c;一个账户最多可以创建10个项目&#xff0c;安装要求填写。 注意点&#xff1a;申请keystory的方法&#xff01;经过测试最简单的方法为&#xff1a; 1、运行进入控制…

SpringMVC+Spring4+Mybatis3集成,开发简单Web项目+源码下载

转载自 SpringMVCSpring4Mybatis3集成&#xff0c;开发简单Web项目源码下载 基本准备工作 1、安装JDK1.6以上版本&#xff0c;安装与配置 2、下载mybatis-3.2.0版&#xff1a;https://repo1.maven.org/maven2/org/mybatis/mybatis/ 3、下载mybatis-spring-1.2.1版&#x…

微软宣布12月15日关闭开源软件托管平台CodePlex

网易科技讯4月1日消息&#xff0c;据Venturebeat报道&#xff0c;微软今天宣布&#xff0c;将关闭开源软件托管平台CodePlex。微软2006年推出这项服务&#xff0c;并决定在今年12月15日将其关闭。 微软公司副总裁布莱恩哈里&#xff08;Brian Harry&#xff09;在博文中写道&am…

C语言 立方体随鼠标转动,HTML5鼠标控制的旋转的立方体

拖拽思路&#xff1a;先定义上下左右重合在一起的六个面的旋转和移动角度立方体效果 transform-style: preserve-3d;定义初始值 transform: perspective(800px) rotateY(-60deg) rotateX(30deg);其中js效果中初始值 var x 30; var y -60;就是初始定义的旋转角度#box{width: 2…

HTML5的基础

HTML5的基础 一、HTML&#xff1a;Hyper Text MarkUp Language(超文本标记语言)。 二、W3C&#xff1a;1.world wide web consortium(万维网联盟)&#xff0c;成立于1994年&#xff0c;WEB技术领域最权威和最具影响力的国际中立性技术标准机构。2.w3c标准包括&#xff1a;结构化…

2018蓝桥杯省赛---java---A--2-(星期一)

题目描述 思路分析 方案一 翻电脑日历得2000年12月31日是周日 方案二 package TEST;class Main{public static void main(String[] args) {int sum0;for (int i 1901; i < 2000; i) {//开始的那天是星期二if((i%4000)||(i%100!0&&i%40)){sum366;}else {sum36…

Mybatis与Hibernate的详细对比

转载自 Mybatis与Hibernate的详细对比 前言 这篇博文我们重点分析一下Mybatis与Hibernate的区别&#xff0c;当然在前面的博文中我们已经深入的研究了Mybatis和Hibernate的原理。 Mybatis 【持久化框架】Mybatis简介与原理【持久化框架】SpringMVCSpring4Mybatis3集成&…

android微信分享之创建工程以及启动微信

android微信分享之创建工程 1、微信jar包在微信--->资源中心-->资源下载 中进行下载&#xff01; 2、项目结构&#xff1a; 3.启动微信&#xff1a; private static final String APP_ID "wxd479d0592270b192";private IWXAPI api;Overrideprotected void on…

android重置系统,安卓手机越用越卡,恢复出厂设置真有用?别瞎搞,看完就明白了!...

安卓手机越用越卡&#xff0c;恢复出厂设置真有用&#xff1f;别瞎搞&#xff0c;看完就明白了&#xff01;现在手机的价格逐渐的开始上升&#xff0c;一部好一点的手机价格还是比较贵的&#xff0c;所以很多人想要节省更多的换机支出&#xff0c;都会想要购买到一款可以使用的…

.NET Core开源组件:后台任务利器之Hangfire

一.简述 Hangfire作为一款高人气且容易上手的分布式后台执行服务&#xff0c;支持多种数据库。在.net core的环境中&#xff0c;由Core自带的DI管理着生命周期&#xff0c;免去了在NF4.X环境中配置always running的麻烦&#xff0c;真正做到开箱即用。 二.安装 Hangfie官方支…

初识CSS3

一、CSS&#xff1a; 1.概念&#xff1a;是一个层叠样式表&#xff0c;用来美化网页的。 2.优势&#xff1a; &#xff08;1&#xff09;内容与表现分离 &#xff08;2&#xff09;表现的统一&#xff0c;并且容易修改 &#xff08;3&#xff09;丰富的样式&#xff0c;使得页面…

2019蓝桥杯省赛---java---A---1(平方和)

题目描述 思路分析 用long保存防止溢出 代码实现 package TEST;public class Main {public static void main(String[] args) {Long cnt 0L;for (int i 1; i < 2019; i)if (check(i)) cnt i*i;System.out.print(cnt);}static boolean check(int n) {String an"&q…

android之微信分享文本

Android微信开发分享文本 1、xml文件说明 添加CheckBox&#xff0c;分享至微信好友还是微信朋友圈2.将APP_ID注册到微信中&#xff1a; api.registerApp(APP_ID); 3.创建EditText用于文本输入 String text editor.getText().toString();if (text null || text.length() 0) …