算法题 — easy — 有效的括号

一. 栈

LIFO(后进先出),其限制是仅允许在表的一端进行插入和删除运算。栈具有push()pop()(返回栈顶元素并出栈)、peek() (返回栈顶元素不出栈)、isEmpty()等基本的方法

在这里插入图片描述

二. 题目:有效的括号

在这里插入图片描述

最开始想到的就是蛮力法,暴力分解字符串,然后从中间开始对比两个字符串,但是实现起来代码量很多

1. replace()函数

根本没想到replace()函数可以用到这道题目,只要在字符串中找到设定的字符就直接替换成空字符,最后字符串的长度就会为0。代码看起来很简单,但是运行起来的时间复杂度很大

class Solution {
    public boolean isValid(String s) {
        int length = s.length() / 2;
		for (int i = 0; i < length; i++) {
			//replace()函数可以连起来使用,也可以分开来使用
			s = s.replace("()", "").replace("{}", "").replace("[]", "");
		}

		return s.length() == 0;

    }
}

2. 栈

toCharArray( ):将字符串对象中的字符转换为一个字符数组

栈的思想是这道题目的核心:

  1. 判断栈是否为空,假如空就push字符
  2. 没有空就比较栈顶字符和字符数组元素,假如匹配成功pop栈中字符,没匹配成功继续push字符
class Solution {
    public boolean isValid(String s) {
    	//创建栈对象
        Stack<Character> stack = new Stack<>();
        //字符串转换成字符数组
        char[] chars = s.toCharArray();
        //数组遍历
        for (char aChar : chars) {
            if (stack.size() == 0) {
                stack.push(aChar);
            } else if (isSym(stack.peek(), aChar)) {
            //stack.peek()查看栈顶元素
                stack.pop();
            } else {
                stack.push(aChar);
            }
        }
        return stack.size() == 0;
    }
    
    private boolean isSym(char c1, char c2) {
        return (c1 == '(' && c2 == ')') || (c1 == '[' && c2 == ']') || (c1 == '{' && c2 == '}');
    }
}

最后比较了一下两种方法的时间效率,栈还是占据很大优势的,虽然replace的代码量很少,使用的很灵活,但是时间效率差了一点。我只想说:栈NB!

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值