LeetCode(20)判断字符串合法括号

问题

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

An input string is valid if:

  1. Open brackets must be closed by the same type of brackets.
  2. Open brackets must be closed in the correct order.

Note that an empty string is also considered valid.

解决,考虑使用栈的先进后出特性来存放这个字符串。将字符串中字符从头开始入栈,如果栈空,则直接入栈。如果非空,则判断栈顶字符。根据不同的情况,判断是否与当前字符与栈顶字符是否构成一个完整的括号。如果是,则栈顶出栈,如果不是,则当前字符入栈。最后,返回栈是否非空,空,表明是合法括号字符串;非空,则有多余的字符不够成合法括号字符串。注意,对于参数的特性情况的判断。

java解决

class Solution {
    public boolean isValid(String s) {
        // 参数合法性判断
        if(s == null){
            return false;
        }
        int size = s.length();
        if (size < 1 || s.equals("")) {
            return true;
        }
        // 以链表作为栈
        LinkedList<Character> stack = new LinkedList<Character>();
        for (int i = 0; i < size; i++) {
            char tmp = s.charAt(i);
            if (stack.size() == 0) {
                stack.push(tmp);
            } else {
                char top = stack.getFirst();
                if (top == '(') {
                    if (tmp == ')') {
                        stack.pop();
                    } else {
                        stack.push(tmp);
                    }
                } else if (top == '[') {
                    if (tmp == ']') {
                        stack.pop();
                    } else {
                        stack.push(tmp);
                    }
                } else if (top == '{') {
                    if (tmp == '}') {
                        stack.pop();
                    } else {
                        stack.push(tmp);
                    }
                } else {
                    return false;
                }
            }
        }
        return stack.isEmpty();
    }
}

 

### 回答1: 使用reverse函数反转leetcode字符串的方法是:将字符串作为参数传入reverse函数,然后将反转后的字符串返回给调用者。例如:let reversedString = reverse("leetcode")。 ### 回答2: 要使用reverse函数反转leetcode这个字符串,可以使用以下步骤: 1. 将字符串"leetcode"转换为字符数组。可以使用字符串的toCharArray()方法,该方法会返回一个字符数组,其中每个元素是字符串的一个字符。 2. 定义两个指针,left和right,分别指向字符数组的首尾。 3. 循环交换left和right指向的字符,然后将left指针向右移动一位,将right指针向左移动一位,直到left指针大于等于right指针。 4. 将反转后的字符数组转换回字符串。可以使用字符数组的valueOf()方法,该方法会将字符数组转换为一个新的字符串。 以下是用Java代码实现上述步骤的示例: ```java public String reverseString(String s) { // 将字符串转换为字符数组 char[] chars = s.toCharArray(); // 定义两个指针 int left = 0; int right = chars.length - 1; // 循环交换字符 while (left < right) { char temp = chars[left]; chars[left] = chars[right]; chars[right] = temp; left++; right--; } // 将字符数组转换为字符串 return String.valueOf(chars); } ``` 通过调用reverseString("leetcode")函数,将会返回字符串"edocteel",即将"leetcode"反转的结果。 ### 回答3: 要使用reverse函数来反转字符串"leetcode",只需将字符串转换为一个列表,然后使用reverse函数来翻转该列表,最后将列表转回字符串即可。 首先,将字符串"leetcode"转换为一个字符列表,可以使用list函数来实现,即list("leetcode"),得到列表['l', 'e', 'e', 't', 'c', 'o', 'd', 'e']。 接下来,使用reverse函数来反转该列表,即reverse(['l', 'e', 'e', 't', 'c', 'o', 'd', 'e'])。 最后,将翻转后的列表转换回字符串,可以使用join函数将列表中的字符连接起来,即''.join(['e', 'd', 'o', 'c', 't', 'e', 'e', 'l'])。 所以,将字符列表['l', 'e', 'e', 't', 'c', 'o', 'd', 'e']翻转并转换为字符串的过程为:''.join(reverse(list("leetcode"))),得到的结果为"edocteel",即字符串"leetcode"反转后的结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值