【Leetcode 每日一题】1963. 使字符串平衡的最小交换次数

问题背景

给你一个字符串 s s s,下标从 0 0 0 开始 ,且长度为偶数 n n n。字符串 恰好 由 n / 2 n / 2 n/2 个开括号 '[' 和 n / 2 n / 2 n/2 个闭括号 ']' 组成。

只有能满足下述所有条件的字符串才能称为 平衡字符串

  • 字符串是一个空字符串,或者
  • 字符串可以记作 A B AB AB,其中 A A A 和 B B B 都是 平衡字符串 ,或者
  • 字符串可以写成 [ C ] [C] [C],其中 C C C 是一个 平衡字符串

你可以交换 任意 两个下标所对应的括号 任意 次数。

返回使 s s s 变成 平衡字符串 所需要的 最小 交换次数。

数据约束

  • n = s . l e n g t h n = s.length n=s.length
  • 2 ≤ n ≤ 1 0 6 2 \le n \le 10 ^ 6 2≤n≤106
  • n n n 为偶数。
  • s [ i ] s[i] s[i] 为'[' 或 ']'
  • 开括号 '[' 的数目为 n / 2 n / 2 n/2,闭括号 ']' 的数目也是 n / 2 n / 2 n/2。

解题过程

分析清楚过程之后代码就很好写,可以通过积分制来判断字符串的平衡情况,遇到左括号就增加,遇到右括号就减少。

遍历的过程中不必真的进行交换,题目保证了字符串一定能转化成平衡的情形,那总积分就不可能为负。

不交换会导致平衡时为零的分数额外进行了一倍的增加,修正一下就可以得到最终的结果。

具体实现

java 复制代码
class Solution {
    public int minSwaps(String s) {
        int res = 0;
        for (char c : s.toCharArray()) {
            if (c == '[' || res == 0) {
                res++;
            } else {
                res--;
            }
        }
        return res >>> 1;
    }
}
相关推荐
ksbglllllll几秒前
ccf3401矩阵重塑(其一)
c++·算法·矩阵
siy233319 分钟前
[c语言日寄]浮点数的排序
c语言·开发语言·数据结构·笔记·学习
king-xxz20 分钟前
力扣No.673.最长递增子序列的个数
数据结构·算法·leetcode
飞奔的马里奥30 分钟前
力扣Hot100——169. 多数元素
java·算法·leetcode
一只_程序媛30 分钟前
【leetcode hot 100 105】从前序与中序遍历序列构造二叉树
算法·leetcode·职场和发展
我也爱吃馄饨32 分钟前
leetcode105为什么可以root.left可以截取到前序遍历二叉树的(0,index),而不是(1,index+1)
数据结构
阿饼24039 分钟前
算法——图论——最短路径(多边权)
c++·算法·动态规划·图论
无名之逆1 小时前
探索Hyperlane:用Rust打造轻量级、高性能的Web后端框架
服务器·开发语言·前端·后端·算法·rust
CYRUS_STUDIO2 小时前
使用 Unicorn 还原变异 CRC32 算法
android·算法·逆向
lmryBC493 小时前
golang-type关键字
java·数据结构·golang