面试问题:检查牙套

这是较容易的编码任务之一,但是您仍然可以在一些初步的技术筛选中达到要求。 问题看起来像这样:

给定仅包含字符'('')''{''}''['']'的字符串,请确定输入字符串是否有效。

括号必须以正确的顺序闭合, "()""()[]{}"均有效,而"(]""([)]"则无效。

描述取自Leetcode(c) 。

您如何解决?

我们一直在使用这项任务进行技术筛选。 有趣的是,有多少人真的不知道该如何处理(请注意,这是Leetcode上的“轻松”类别)。 有些人尝试使用正则表达式。 有些人试图想出一种蛮力解决方案,遍历字符串并计算开括号和闭括号。 但是,如果您考虑一下,您将理解,两者都不足以。 例如,如何在([)]最简单的情况下计数帮助?

您应该想到的解决方案是stack ,但是如果您从未接受过解决编码问题的培训,则可能不会。 为什么要堆叠? 好吧,因为仅当您看到闭合的括号时,才可以检查这对括号或括号的完整性; 但这意味着打开的那个应该放在某个地方等待,并在某些数据结构之上进行检查。 允许LIFO访问的结构是一个堆栈 。 碰巧我们在Java中有一个现成的Stack类 。

那么,简单的解决方案如何?
基本思想是,您开始遍历字符串。 如果符号是打开符号之一,则将其推入堆栈。 如果即将关闭,您可以查看堆栈,看看是否匹配。 如果是,则将其从堆栈中弹出。 如果堆栈最后为空,则返回true。

import java.util.*;public class Groups{private static final List<Character> OPEN = Arrays.asList('(', '{', '[');private static final List<Character> CLOSE = Arrays.asList(')', '}', ']');public static boolean groupCheck(String s){if (s == null || s.length() == 0) {return true;}Stack<Character> stack = new Stack<>();for (int i = 0; i < s.length(); i++) {char current = s.charAt(i);if (isOpen(current)) {stack.push(current);} else {if (stack.isEmpty()) {return false;}char prev = stack.peek();if (isMatch(prev, current)) {stack.pop();}}}return stack.isEmpty();}private static boolean isOpen(char c) {return OPEN.contains(c);}private static boolean isClose(char c) {return CLOSE.contains(c);}private static boolean isMatch(char prev, char next) {return isOpen(prev) && (OPEN.indexOf(prev) == CLOSE.indexOf(next));}}

还有其他解决方法吗? 如果您不敢想到该怎么办? 与往常一样,有多种方法可以解决问题。 让我们看这个例子: ([]){}

让我们尝试替换正确匹配的对:

“([]] {}”。replace(“ []”,“”)=>“(){}”。replace(“(()”,“”)=>“ {}”。replace(“ {} ”,“”)=>“”

因此,我们可以循环遍历字符串,用空字符串替换“ {}”,“()”和“ []”。 当结果为空时,表示所有对都匹配。 如果没有变空怎么办? 我们如何摆脱周期? 好吧,我们需要检查一轮替换后字符串的长度是否已更改。 如果还没有,那么我们就破产了。

public class Groups{public static boolean groupCheck(String s) {int len;do {len = s.length();s = s.replace("()", "");s = s.replace("{}", "");s = s.replace("[]", "");} while (len != s.length());return s.length() == 0;}
}

看起来更好。 简单易读,但实际上是否更好? 我会说不,不是。 为什么? 好吧,因为String类是不可变的 ,因此每次执行s.replace()时,我们都会在堆上创建一个新的字符串对象。

那么,如何最好地做到这一点呢? 我们可以使用StringBuilder类重写代码吗? 好吧,不是直接的,因为它没有replaceAll方法。 您必须使用现有的replace方法自己编写。 Apache Commons库中有一个StrBuilder类,它确实具有此方法,但它不是标准的Java类,您必须添加一个依赖项。

因此,即使这个简单的任务也可以给您一些思考。 但是,对于面试,任何解决方案都可以。 如果堆栈不是您脑海中最先想到的,那么您可以不做任何事情。

翻译自: https://www.javacodegeeks.com/2017/02/interview-questions-verify-braces.html

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

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

相关文章

python字符串长度_如何使用python获取字符串长度?哪些方法?

掌握多种python技巧&#xff0c;对于我们更好的灵活应用python是非常重要的&#xff0c;比如接下来给大家介绍的获取字节长度&#xff0c;那大家脑海里就该有印象了&#xff0c;有几种方法呢&#xff1f;一起来看下吧~1、使用len&#xff08;&#xff09;函数 这是最直接的方法…

C++内存

在C中&#xff0c;内存分成5个区&#xff0c;他们分别是堆、栈、自由存储区、全局/静态存储区和常量存储区。 栈&#xff0c;就是那些由编译器在需要的时候分配&#xff0c;在不需要的时候自动清楚的变量的存储区。里面的变量通常是局部变量、函数参数等。 堆&#xff0c;就是那…

Dijkstra算法——计算一个点到其他所有点的最短路径的算法

迪杰斯特拉算法百度百科定义&#xff1a;传送门 gh大佬博客&#xff1a;传送门 迪杰斯特拉算法用来计算一个点到其他所有点的最短路径&#xff0c;是一种时间复杂度相对比较优秀的算法 O&#xff08;n2&#xff09;&#xff08;相对于Floyd算法来说&#xff09; 是一种单源最短…

浅谈java中extends与implements的区别

Extends可以理解为全盘继承了父类的功能。implements可以理解为为这个类附加一些额外的功能&#xff1b;interface定义一些方法,并没有实现,需要implements来实现才可用。extend可以继承一个接口,但仍是一个接口,也需要implements之后才可用。对于class而言&#xff0c;Extends…

注意力机制 神经网络_图注意力网络(GAT)

引言作者借鉴图神经网络中的注意力机制&#xff0c;提出了图注意力神经网络架构&#xff0c;创新点主要包含如下几个&#xff1a;①采用masked self-attention层&#xff0c;②隐式的对邻居节点采用不同权重③介绍了多头注意力机制。 在作者的Introduction中&#xff0c;该论文…

java版问题

1.必填项在初次保存后应该已经有值了&#xff0c;怎么会加载数据又是空的的&#xff1f; 2.客户类型 企业性质&#xff1f; 一般机构、上市公司.... 3.文档管理-->上传文档&#xff0c;如果左侧选中文档节点时&#xff0c;上传文档时是否默认选中文档节点。 转载于:https:/…

html5标签属性大全_HTML5中video标签如何使用

HTML5中的video标签用于播放视频文件的&#xff0c;在video标签中我们可以设置窗口的宽高&#xff0c;视频的自动播放&#xff0c;循环播放以及视频的封面图片等等HTML5是下一代HTML&#xff0c;新增了许多新的标签&#xff0c;这些标签实现了许多新的功能。并且还减少了对外部…

Java中@Override的作用

Override是伪代码,表示重写(当然不写也可以)&#xff0c;不过写上有如下好处: 1、可以当注释用,方便阅读&#xff1b; 2、编译器可以给你验证Override下面的方法名是否是你父类中所有的&#xff0c;如果没有则报错。例如&#xff0c;你如果没写Override&#xff0c;而你下面的…

java程序中用户名和密码_在Java应用程序中使用密码术

java程序中用户名和密码这篇文章描述了如何使用Java密码体系结构 &#xff08;JCA&#xff09;&#xff0c;该体系结构使您可以在应用程序中使用密码服务。 Java密码体系结构服务 JCA提供了许多加密服务&#xff0c;例如消息摘要和签名 。 这些服务可通过特定于服务的API来访…

C++ setw和setfill

在C中&#xff0c;setw(int n)用来控制输出间隔。 例如: cout<<s<<setw(8)<<a<<endl; 则在屏幕显示 s a //s与a之间有7个空格&#xff0c;setw()只对其后面紧跟的输出产生作用&#xff0c;如上例中&#xff0c;表示a共占8个位置&#xff0c;不…

Linux快捷键

附上一些其他较长使用的快捷键&#xff1a; ctrl w —往回删除一个单词&#xff0c;光标放在最末尾 ctrl k —往前删除到末尾&#xff0c;光标放在最前面&#xff08;可以使用ctrla&#xff09; ctrl u 删除光标以前的字符 ctrl k 删除光标以后的字符 ctrl a 移动光标至的…

会python基础可以找到工作吗_我大学退学,现在 28 岁,如果零基础开始学 python,可以找到工作吗?...

作为一名IT行业从业者&#xff0c;同时也是一名教育工作者&#xff0c;我来回答一下这个问题。 首先&#xff0c;对于28岁且没有获得大学文凭的初学者来说&#xff0c;要想通过学习Python来找到工作还是具有一定难度的&#xff0c;一方面原因是目前开发岗位通常都有一定的学历要…

测试Java EE 8规范

Java EE 8平台肯定在过去的几个月中一直在发展。 规范已经发布了早期的草案评审&#xff0c;里程碑甚至最终版本。 实际上&#xff0c;随着JSF 2.3的发布&#xff0c;JSR-372才刚刚进入最终版本。 有关更多信息&#xff0c;请参见 Arjan的帖子 。 它有幸成为JSR-372专家组的成…

C++ this

对象a的内存地址和this指针的一模一样(都是0017F7E8)&#xff1b;而当运行到对象b的时候&#xff0c;它的内存地址又和它所对应的this指针指向的内存地址一模一样了(都是0017F7DC)。这就说明了this指针变量记录的是当前对象的内存地址&#xff0c;即this指针指向当前的对象

修改weblogic端口的方法

修改weblogic端口的方法 修改weblogic的端口常用的有两种方法 方法一.登录weblogic的console。如&#xff1a;http://localhost:7001/console/  1).在环境--服务器节点中点击你要修改的服务器的端口的名称(如下图&#xff1a;AdminServer(管理)) 2).上述步骤打开的页面如下图…

什么是JAX-RS注释? (第2部分)

JAX-RS注释概述&#xff08;第2部分&#xff09; 这是一个由三部分组成的系列&#xff0c;介绍了用于实现REST端点的注释。 在JAX-RS注释的第一部分中&#xff0c;您了解了&#xff1a; ApplicationPath批注 Path注释 GET HTTP方法注释 POST HTTP方法注释 PUT HTTP方法…

eclipse 快捷键组合

更多快捷键组合可在Eclipse按下ctrlshiftL查看。 让我们按照使用频率来看看我最爱用的一些热键组合。&#xff08;注&#xff1a;以下内容在Eclipse3.02及一上版本通过测试&#xff09; 1. Control-Shift-T: 打开类型&#xff08;Open type&#xff09;。如果你不是有意磨洋工…

java实体类转map_十五道经典面试题-JAVA基础篇

十五道JAVA基础面试题送给有需要的童鞋&#xff0c;但是不得不多提醒一句&#xff0c;打铁还需自身硬&#xff0c;计算机软件这个行业&#xff0c;技术和学历才是王道。好了&#xff0c;废话不多说&#xff0c;上菜&#xff1a;一&#xff1a;面向对象的特征有哪些方面 1. 抽象…

C++ 指针函数和函数指针

1、指针函数 &#xff08;1&#xff09;基本概念 指针函数&#xff1a;顾名思义就是带有指针的函数&#xff0c;即其本质是一个函数&#xff0c;只不过这种函数返回的是一个对应类型的地址。 &#xff08;2&#xff09;定义式 type *func(type , type) 如&#xff1a;int…

B树

B树是为磁盘或其他直接存储的辅存设备而设计的一种平衡搜索树。 B树类似于红黑树&#xff0c;但在降低磁盘I/O操作数方面要更好一些。许多数据库系统使用B树或者B树的变种来存储信息。 B树与红黑树的不同之处在于B树的结点可以有很多孩子&#xff0c;从数个到数千个。也就是说&…