【代码随想录】算法训练计划11

1、20. 有效的括号

题目:
给定一个只包括 ‘(’,‘)’,‘{’,‘}’,‘[’,‘]’ 的字符串 s ,判断字符串是否有效。
有效字符串需满足:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
每个右括号都有一个对应的相同类型的左括号。

思路:
  • 注意for range 的v 和s[i] 类型是不同的即可
func isValid(s string) bool {
    // 代码一刷
    map1 := map[rune]rune {
        ')' : '(',
        '}' : '{',
        ']' : '[',
    }
    stack1 := make([]rune, 0)
    for _,v := range s {
        if len(stack1) > 0 && map1[v] != ' ' && stack1[len(stack1)-1] == map1[v] {
            stack1 = stack1[:len(stack1)-1]
        } else {
            stack1 = append(stack1, v)
        }
    }
    if len(stack1) == 0 {
        return true
    }
    return false
}

2、1047. 删除字符串中的所有相邻重复项

题目:
给出由小写字母组成的字符串 S,重复项删除操作会选择两个相邻且相同的字母,并删除它们。
在 S 上反复执行重复项删除操作,直到无法继续删除。
在完成所有重复项删除操作后返回最终的字符串。答案保证唯一。

思路:
  • go for range时候把它当成rune了,就uint32
  • 想邻的
func removeDuplicates(s string) string {
    // 代码一刷
    stack := make([]rune, 0)
    for _,v := range s {
        if len(stack) > 0 && v == stack[len(stack)-1] {
            stack = stack[: len(stack)-1]
        } else {
            stack = append(stack, v)
        }
    }
    return string(stack)
}

3、150. 逆波兰表达式求值

题目:
输入:tokens = [“4”,“13”,“5”,“/”,“+”]
输出:6
解释:该算式转化为常见的中缀算术表达式为:(4 + (13 / 5)) = 6

思路:
  • Atoi i 代表 int
  • 遇见算数符号,,就将前两位数字运算结果代替前两位数字,即可
func evalRPN(tokens []string) int {
    // 代码一刷
    stack := make([]int, 0)
    for _,v := range tokens {
        if v != "+" && v != "-" && v != "*" && v != "/" {
            val, _ := strconv.Atoi(v)
            stack = append(stack, val)
        } else {
            switch v {
            case "+":
                val := stack[len(stack)-1] + stack[len(stack)-2]
                stack = stack[:len(stack)-2]
                stack = append(stack, val)
            case "-":
                val := stack[len(stack)-2] - stack[len(stack)-1]
                stack = stack[:len(stack)-2]
                stack = append(stack, val)
            case "*":
                val := stack[len(stack)-2] * stack[len(stack)-1]
                stack = stack[:len(stack)-2]
                stack = append(stack, val)
            case "/":
                val := stack[len(stack)-2] / stack[len(stack)-1]
                stack = stack[:len(stack)-2]
                stack = append(stack, val)
            }
        }
    }
    return stack[0]
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不之道

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值