LeetCode——5770. 反转表达式值的最少操作次数(Minimum Cost to Change the Final Value of Expression)[困难]——分析及代码(Java)

LeetCode——5770. 反转表达式值的最少操作次数[Minimum Cost to Change the Final Value of Expression][困难]——分析及代码[Java]

一、题目

给你一个 有效的 布尔表达式,用字符串 expression 表示。这个字符串包含字符 ‘1’,‘0’,’&’(按位 与 运算),’|’(按位 或 运算),’(’ 和 ‘)’ 。

  • 比方说,"()1|1" 和 “(1)&()” 不是有效 布尔表达式。而 “1”, “(((1))|(0))” 和 “1|(0&(1))” 是 有效 布尔表达式。

你的目标是将布尔表达式的 值 反转 (也就是将 0 变为 1 ,或者将 1 变为 0),请你返回达成目标需要的 最少操作 次数。

  • 比方说,如果表达式 expression = “1|1|(0&0)&1” ,它的 值 为 1|1|(0&0)&1 = 1|1|0&1 = 1|0&1 = 1&1 = 1 。我们想要执行操作将 新的 表达式的值变成 0 。

可执行的 操作 如下:

  • 将一个 ‘1’ 变成一个 ‘0’ 。
  • 将一个 ‘0’ 变成一个 ‘1’ 。
  • 将一个 ‘&’ 变成一个 ‘|’ 。
  • 将一个 ‘|’ 变成一个 ‘&’ 。

注意:’&’ 的 运算优先级 与 ‘|’ 相同 。计算表达式时,括号优先级 最高 ,然后按照 从左到右 的顺序运算。

示例 1:

输入:expression = "1&(0|1)"
输出:1
解释:我们可以将 "1&(0|1)" 变成 "1&(0&1)" ,执行的操作为将一个 '|' 变成一个 '&' ,执行了 1 次操作。
新表达式的值为 0 。

示例 2:

输入:expression = "(0&0)&(0&0&0)"
输出:3
解释:我们可以将 "(0&0)&(0&0&0)" 变成 "(0|1)|(0&0&0)" ,执行了 3 次操作。
新表达式的值为 1 。

示例 3:

输入:expression = "(0|(1|0&1))"
输出:1
解释:我们可以将 "(0|(1|0&1))" 变成 "(0|(0|0&1))" ,执行了 1 次操作。
新表达式的值为 0 。

提示:

  • 1 <= expression.length <= 10^5
  • expression 只包含 ‘1’,‘0’,’&’,’|’,’(’ 和 ‘)’
  • 所有括号都有与之匹配的对应括号。
  • 不会有空的括号(也就是说 “()” 不是 expression 的子字符串)。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/minimum-cost-to-change-the-final-value-of-expression
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

二、分析及代码

1. 栈 + 动态规划

(1)思路

设计 3 个栈,分别存储表达式计算的结果值、反转当前表达式的最小操作次数和符号。
从前向后遍历字符串,结合动态规划方法,依次计算 [0, 当前位置] 区间内字符串表达式的结果值、反转所需的最小操作次数,直至完成遍历。

(2)代码

class Solution {
   
    public int minOperationsToFlip(String expression) {
   
        char[] exp = expression.toCharArray();//转为char[]简化代码
        Deque<Integer> num = new LinkedList<>
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值