这星期听别人说在做LeetCode,让他分享一题来看看。试了感觉挺有意思,可以培养自己的思路,还能方便的查看优秀的解决方案。准备自己也开始。

解决方案通常有多种多样,我觉得把自己的解决思路记录下来,阶段性查看,一定能对自己有帮助。

这是我做的第一题,所以记录也从这题开始,之后尽力以简短的说明,描述出思路,方便以后能回顾到简介明了的记录。

20. Valid Parentheses

Given a string containing just the characters '('')''{''}''[' and ']', determine if the input string is valid.

The brackets must close in the correct order, "()" and "()[]{}" are all valid but "(]" and "([)]" are not.

给定一个字符串,只包含三种括号字符,需要确认是否有效

//一开始审题不仔细,没有注意到只有括号字符,所以按有其他字符思考了

//思路:假如输入的字符有效(即所有括号都被正确闭合),那在嵌套的最里层,一定存在至少一对括号,里面没有其他任何括号字符。
//那只要找到它,把它和其中的内容一起从字符串中删除。剩下的字符串,要么没有任何一个括号字符,要么仍然至少存在一对括号里面没有其他括号字符。
//循环,剔除所有正常使用的成对的括号,剩下的字符串中,如果还有括号字符则输入值无效,反之有效 //文字描述可能不够清晰,上代码
/**
* @param {string} s
* @return {boolean}
*/
var isValid = function(s) {
var str = s;
var reg1=new RegExp(/\([^\[\]\{\}\(\)]*\)/);//匹配()中无其他括号字符的字符串
var reg2=new RegExp(/\[[^\[\]\{\}\(\)]*\]/);
var reg3=new RegExp(/\{[^\[\]\{\}\(\)]*\}/);
var reg4=new RegExp(/[\[\]\{\}\(\)]/);
while(reg1.test(str)||reg2.test(str)||reg3.test(str)){//如果还有任意一种正确的成对括号,则继续循环
str = str.replace(reg1,'');//如匹配到正确的成对括号字符串,用空字符串替换,从而删除
str = str.replace(reg2,'');
str = str.replace(reg3,'');
}
return !reg4.test(str);//检测最后剩下的字符串,如有任意括号字符,则输入无效,返回false
};

以上是第一次做LeetCode,提交以后把我给惭愧的,做的慢都不说,运行效率惨不忍睹。马上意识到觉得自己一定是用了不太好的方法,决定去借鉴别人的思路

public boolean isValid(String s) {
Stack<Character> stack = new Stack<Character>();
for (char c : s.toCharArray()) {
if (c == '(')
stack.push(')');
else if (c == '{')
stack.push('}');
else if (c == '[')
stack.push(']');
else if (stack.isEmpty() || stack.pop() != c)
return false;
}
return stack.isEmpty();
}

讨论中最热的一个是java写的,最然不会java,但还好这题写的简单,不会java也不妨碍理解其思路

一开始被第三个else if整蒙了,怎么都想不通为什么堆里最后的元素不等于循环的字符,就是无效输入,有其他非括号字符怎么办。

回去看题,这才发现自己审题不仔细,没看到只有括号字符...

我对热门解法思路的理解:假如输入有效,则从左往右第一个右括号前面一个字符必须为其对应的左括号,否则无效。如对应则此对括号匹配,继续向右的第一个右括号,和其前面第一个非已匹配 的左括号必须对应,否则无效。。。到最后如有效则恰好所有括号字符两俩匹配

利用这一特点。把输入字符分割成数组,遍历,匹配到左括号,则使用栈记录其对应的右括号(用于与匹配的括号对比)。如遇到右括号,但栈空,则说明出现单独的右括号,输入无效返回false;栈不空,则把最后添加的元素拿出来和遍历到的右括号对比,如一样,则说明和其前面最近的一个左括号成对,是正确使用,反之输入无效,返回false;

循环完,如栈空,则字符都两两匹配,无单独左括号,输入有效返回true,反正返回false。

对其解法,我觉得有两点让我很有启发,

1.巧妙利用无其他字符,想到括号对应规则,让函数只需要遍历一遍输入的字符串转成的数组,效率相当高

2.用栈来存储左括号对应的右括号,利用栈后进先出的特点,让右括号可以和其前面最近的左括号尝试匹配。pop删除并返回,不匹配直接终止程序,返回false,当然不用管栈,匹配到则正好删除匹配好了的括号,让下一个右括号能匹配最近的、未匹配的左括号

其构想让我觉得很有意思,禁不住想自己写一遍

/**
* @param {string} s
* @return {boolean}
*/
var isValid = function(s) {
var stack = [];//他使用栈,主要就是利用其后入先出,这样的话js用数组也能实现同样的功能
var strArr = s.split('');
for(var i in strArr){
if(strArr[i] == '(') stack.push(')');
else if(strArr[i] == '{') stack.push('}');
else if(strArr[i] == '[') stack.push(']');
else if(stack.length == 0||stack.pop() != strArr[i]) return false;
}
return stack.length == 0;
};
//解法一模一样,只是把换成了js实现

换成这种解法,运行效率果然大幅度提升。一想到其他题也能领略到其他优秀思路,不经有些激动。

不过由于自己水平还不够,做题效率不高,而且还需要学习其他知识,所以不准备短时间多做。一周7题,争取能长时间保持,相信哪怕一天只一题,积累下来,也能提高自己。

LeetCode解题笔记 - 20. Valid Parentheses的更多相关文章

  1. leetCode练题——20. Valid Parentheses

    1.题目 20. Valid Parentheses——Easy  Given a string containing just the characters '(', ')', '{', '}',  ...

  2. LeetCode解题报告—— Longest Valid Parentheses

    Given a string containing just the characters '(' and ')', find the length of the longest valid (wel ...

  3. LeetCode记录之20——Valid Parentheses

    09.18更新算法采用栈的思想解决,方法①所示. 本题主要是找是否有匹配的字符串,因为还没有复习到栈之类的知识点,只能还是采用暴力方法了,后期会补上更加优化的算法.我的思路就是先遍历一遍找是否有匹配的 ...

  4. &lt;LeetCode OJ&gt; 20. Valid Parentheses

    Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if the inpu ...

  5. 【leetcode❤python】 20. Valid Parentheses

    #-*- coding: UTF-8 -*-#利用栈的思想#如果输入的左测扩则入栈,如果输入为右侧扩,判断其是否与当前栈顶配对,如果匹配则删除这一对,否则return False#'(', ')', ...

  6. leetcode个人题解——#20 Valid Parentheses

    class Solution { public: bool isValid(string s) { stack<char> brackts; ; i < s.size(); i++) ...

  7. [Leetcode][Python]20: Valid Parentheses

    # -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com' 20: Valid Parentheseshttps://oj.leetcod ...

  8. 《LeetBook》leetcode题解(20):Valid Parentheses[E]——栈解决括号匹配问题

    我现在在做一个叫<leetbook>的免费开源书项目,力求提供最易懂的中文思路,目前把解题思路都同步更新到gitbook上了,需要的同学可以去看看 书的地址:https://hk029.g ...

  9. 20. Valid Parentheses【leetcode】

    20. Valid Parentheses Given a string containing just the characters '(', ')', '{', '}', '[' and ']', ...

随机推荐

  1. Java生鲜电商平台-服务化后的互联网架构实战(针对生鲜电商小程序或者APP)

    Java生鲜电商平台-服务化后的互联网架构实战(针对生鲜电商小程序或者APP) “微服务架构”的话题非常之火,很多朋友都在小窗我,说怎么做服务化?解答“怎么做”之前,先得了解“为什么做”. 画外音:做 ...

  2. 使用objc runtime实现iOS绿色的懒加载

    使用objc runtime实现懒加载 地址:AutoPropertyCocoa 本文所指懒加载形式如下 - (id)lazyloadProperty{ if(_lazyloadProperty == ...

  3. 编译原理之LL(1)文法的判断,递归下降分析程序

    1. 文法 G(S): (1)S -> AB (2)A ->Da|ε (3)B -> cC (4)C -> aADC |ε (5)D -> b|ε 验证文法 G(S)是不 ...

  4. VS2017创建的单元测试不支持顺序测试

      问题:使用IDE创建的单元测试项目,标准引用是,导致不能添加顺序测试,复制其它项目的顺序测试文件进行编辑时,也会提示基于MSTest V2的测试不能用于顺序测试     解决办法: 移除自带的NU ...

  5. VMware Workstation虚拟机安装CentOS-7-Minimal经验分享

    本文主要为0基础的小白准备,有一定经验的大神请忽略.因为最近刚接触linux,在其中也是遇到无数的弯路,本着互惠互利原则,特写这个博客,希望后来人能少走点弯路,更快的进入状态.话不多说,上货. 一,首 ...

  6. 池化技术(二)HikariCP是如何管理数据库连接的?

    基于依赖程序的版本信息:HikariCP:3.3.1               驱动程序mysql-connector-java:8.0.17 上一篇:Druid是如何管理数据库连接的 零.类图和流 ...

  7. nginx基础(3)

    目录 HTTP首部 1.通用首部 2.请求首部 2.1 必有首部 2.2 条件请求首部 2.3 安全相关首部 3.响应首部 3.1 必有首部 3.2 协商首部 3.3 安全相关首部 4.实体首部 4. ...

  8. linux用户组相关,密码相关,文件操作,和启动级别

    一.开机重启和用户切换 注意,当关机或重启前,都应当先执行一下sync指令,把内存的数据写入磁盘,防止数据丢失. shutdown命令 shutdown -h now :立即关机 shutdown - ...

  9. Python实现单链表数据的添加、删除、插入操作

    Python实现单链表数据的添加.删除.插入操作 链表的定义: 链表(linked list)是由一组被称为结点的数据元素组成的数据结构,每个结点都包含结点本身的信息和指向下一个结点的地址.由于每个结 ...

  10. Nginx 常用模块

    Nginx 常用模块 1. ngx_http_autoindex_module # ngx_http_autoindex_module模块处理以斜杠字符(' / ')结尾的请求,并生成一个目录列表. ...