leetcode 3713. 最长的平衡子串 I 中等

给你一个由小写英文字母组成的字符串 s

如果一个 子串 中所有 不同 字符出现的次数都 相同 ,则称该子串为 平衡 子串。

请返回 s最长平衡子串长度

子串 是字符串中连续的、非空的字符序列。

示例 1:

输入: s = "abbac"

输出: 4

解释:

最长的平衡子串是 "abba",因为不同字符 'a''b' 都恰好出现了 2 次。

示例 2:

输入: s = "zzabccy"

输出: 4

解释:

最长的平衡子串是 "zabc",因为不同字符 'z''a''b''c' 都恰好出现了 1 次。

示例 3:

输入: s = "aba"

输出: 2

解释:

最长的平衡子串之一是 "ab",因为不同字符 'a''b' 都恰好出现了 1 次。另一个最长的平衡子串是 "ba"

提示:

  • 1 <= s.length <= 1000
  • s 仅由小写英文字母组成。

分析:字符串长度最大为 1000,可以暴力枚举每一个字串,检查是否平衡。

cpp 复制代码
int longestBalanced(char* s) {
    int n=strlen(s),ret=1;
    for(int i=0;i<n-1;++i)
    {
        int cnt[26]={0},val=1;cnt[s[i]-'a']++;
        for(int j=i+1;j<n;++j)
        {
            int f=1;
            cnt[s[j]-'a']++,val=fmax(val,cnt[s[j]-'a']);
            for(int i=0;i<26&&f;++i)
                if(cnt[i]&&cnt[i]!=val)f=0;
            if(f)ret=fmax(ret,j-i+1);
        }
    }
    return ret;
}
相关推荐
im_AMBER2 小时前
Leetcode 159 无重复字符的最长子串 | 长度最小的子数组
javascript·数据结构·学习·算法·leetcode
郝学胜-神的一滴2 小时前
[力扣 105]二叉树前中后序遍历精讲:原理、实现与二叉树还原
数据结构·c++·算法·leetcode·职场和发展
sheeta19982 小时前
LeetCode 每日一题笔记 日期:2026.04.20 题目:2078.两栋颜色不同而距离最远的房子
笔记·算法·leetcode
承渊政道3 小时前
【递归、搜索与回溯算法】(floodfill算法:从不会做矩阵题,到真正掌握搜索扩散思想)
数据结构·c++·算法·leetcode·矩阵·dfs·bfs
剑挑星河月3 小时前
73.矩阵置零
数据结构·算法·leetcode·矩阵
_深海凉_4 小时前
LeetCode热题100-单词拆分
算法·leetcode·职场和发展
_深海凉_14 小时前
LeetCode热题100-有效的括号
linux·算法·leetcode
@BangBang1 天前
leetcode (4): 连通域/岛屿问题
算法·leetcode·深度优先
Mr_pyx1 天前
【LeetCode Hot 100】 除自身以外数组的乘积(238题)多解法详解
算法·leetcode·职场和发展
故事和你911 天前
洛谷-数据结构-1-3-集合3
数据结构·c++·算法·leetcode·贪心算法·动态规划·图论