【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;
    }
}
相关推荐
超级码力6661 天前
【Latex文件架构】Latex文件架构模板
算法·数学建模·信息可视化
穿条秋裤到处跑1 天前
每日一道leetcode(2026.04.29):二维网格图中探测环
算法·leetcode·职场和发展
Merlos_wind1 天前
HashMap详解
算法·哈希算法·散列表
汉克老师1 天前
GESP2025年3月认证C++五级( 第三部分编程题(1、平均分配))
c++·算法·贪心算法·排序·gesp5级·gesp五级
Yzzz-F1 天前
Problem - 2205D - Codeforces
算法
智者知已应修善业1 天前
【51单片机2个按键控制流水灯运行与暂停】2023-9-6
c++·经验分享·笔记·算法·51单片机
Halo_tjn1 天前
Java Set集合相关知识点
java·开发语言·算法
生成论实验室1 天前
《事件关系阴阳博弈动力学:识势应势之道》第四篇:降U动力学——认知确定度的自驱演化
人工智能·科技·神经网络·算法·架构
AI科技星1 天前
全域数学·72分册:场计算机卷【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
科研前沿1 天前
镜像孪生VS视频孪生核心技术产品核心优势
大数据·人工智能·算法·重构·空间计算