LeetCode

问题描述

给定一个只包括 '(',')','{','}','[',']' 的字符串 s ,判断字符串是否有效。

有效字符串需满足:

左括号必须用相同类型的右括号闭合。

左括号必须以正确的顺序闭合。

每个右括号都有一个对应的相同类型的左括号。


原因分析:

困扰点一:

例如:关于接口类实例化的理解:

  • new LinkedList<Character>():在堆内存中创建一个LinkedList对象。这个对象是LinkedList类的一个实例。

  • Deque<Character> stack:声明一个引用变量stack,它的类型是Deque接口。这意味着这个变量可以指向任何实现了Deque接口的类的对象。

  • stack变量指向刚刚创建的LinkedList对象。因为LinkedList实现了Deque接口,所以这是允许的。
    new LinkedList的意义在哪里?

  • new LinkedList()的意义在于创建一个具体的、实现了Deque接口的LinkedList对象。虽然我们通过Deque接口的引用来操作这个对象,但实际在内存中的对象是LinkedList类型的。
  • 这样做的好处是:我们可以利用多态性。我们可以在不改变使用Deque接口的代码的情况下,更换具体的实现类。比如,我们可以将new LinkedList<>()改为new ArrayDeque<>(),而使用stack的代码不需要改变。

困扰点二:

java 复制代码
for (char c : s.toCharArray()) {
    // 循环体
}

/*
for (元素类型 临时变量 : 集合或数组) {
    // 使用临时变量
}

String s = "hello";
char[] chars = s.toCharArray(); 
// 结果:['h','e','l','l','o']

char[] chars = s.toCharArray();
for (int i = 0; i < chars.length; i++) {
    char c = chars[i];
    // 循环体
}*/

解决方案:

java 复制代码
class Solution {
    public boolean isValid(String s) {
        if(s.length() % 2 != 0)
        return false;
        Deque<Character> stack =new ArrayDeque<Character>();
for (int i = 0; i < s.length(); i++) {
    char c = s.charAt(i);
    if (c =='(' ||c == '[' || c == '{'){
        stack .push(c);
    }else{
        if(stack.isEmpty())return false;
        char top = stack.pop();
        if (c == ')' && top != '(') return false;
                if (c == ']' && top != '[') return false;
                if (c == '}' && top != '{') return false;
            
    
    }
        }
         return stack.isEmpty();
    }
    }
    ```
相关推荐
而后笑面对5 分钟前
关于力扣2025.10.4每日 11.盛最多雨水的容器
算法·leetcode·职场和发展
自信的小螺丝钉1 小时前
Leetcode 295. 数据流的中位数 堆
leetcode·
天选之女wow1 小时前
【代码随想录算法训练营——Day27(Day26休息)】贪心算法——455.分发饼干、376.摆动序列、53.最大子数组和
算法·leetcode·贪心算法
未知陨落2 小时前
LeetCode:84.完全平方数
算法·leetcode·动态规划
dragoooon3412 小时前
[优选算法专题三.二分查找——NO.24搜索旋转排序数组中的最⼩值]
数据结构·leetcode·动态规划
Haooog12 小时前
654.最大二叉树(二叉树算法)
java·数据结构·算法·leetcode·二叉树
Swift社区12 小时前
LeetCode 392 判断子序列
算法·leetcode·职场和发展
Asmalin17 小时前
【代码随想录day 30】 力扣 763. 划分字母区间
算法·leetcode·职场和发展
小欣加油17 小时前
leetcode 526 优美的排列
c++·算法·leetcode·职场和发展·深度优先·剪枝
代码充电宝18 小时前
LeetCode 算法题【简单】49. 字母异位词分组
java·算法·leetcode·面试·哈希算法