【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 si si 为'' 或 ''
  • 开括号 '' 的数目为 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;
    }
}
相关推荐
晚风予卿云月几秒前
二分算法练习
数据结构·c++·算法·竞赛·算法随笔
菜菜的顾清寒5 分钟前
力扣HOT100(47) 二叉树的层序遍历
算法·leetcode·深度优先
周末也要写八哥6 分钟前
牛顿迭代Python代码实现
算法
KaMeidebaby20 分钟前
卡梅德生物技术快报|基因测序技术在 46,XY 性发育障碍变异筛查中的流程与数据分析
服务器·前端·数据库·人工智能·算法·数据挖掘·数据分析
ZengLiangYi22 分钟前
SourceAdapter 插件架构详解
javascript·算法·架构
妄想出头的工业炼药师30 分钟前
特征检测和特征筛选
算法·开源
cxr82832 分钟前
高分子复合材料 AI 逆向设计合——学证明、算法实现、验证数据与学术资源全集
人工智能·线性代数·算法
ZengLiangYi39 分钟前
如何解析 5 种完全不同格式的 AI 对话
javascript·人工智能·算法
计算机安禾43 分钟前
【算法设计与分析】第29篇:启发式与元启发式搜索方法综述
java·数据库·算法
我叫袁小陌1 小时前
数据结构详解与算法关联指南
算法