🚀 算法题 🚀 |
🌲 算法刷题专栏 | 面试必备算法 | 面试高频算法 🍀
🌲 越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨
🌲 作者简介:硕风和炜,CSDN-Java领域新星创作者🏆,保研|国家奖学金|高中学习JAVA|大学完善JAVA开发技术栈|面试刷题|面经八股文|经验分享|好用的网站工具分享💎💎💎
🌲 恭喜你发现一枚宝藏博主,赶快收入囊中吧🌻
🌲 人生如棋,我愿为卒,行动虽慢,可谁曾见我后退一步?🎯🎯
🚀 算法题 🚀 |
🚩 题目链接
⛲ 题目描述
给你一个仅由 0 和 1 组成的二进制字符串 s 。
如果子字符串中 所有的 0 都在 1 之前 且其中 0 的数量等于 1 的数量,则认为 s 的这个子字符串是平衡子字符串。请注意,空子字符串也视作平衡子字符串。
返回 s 中最长的平衡子字符串长度。
子字符串是字符串中的一个连续字符序列。
示例 1:
输入:s = “01000111”
输出:6
解释:最长的平衡子字符串是 “000111” ,长度为 6 。
示例 2:
输入:s = “00111”
输出:4
解释:最长的平衡子字符串是 “0011” ,长度为 4 。
示例 3:
输入:s = “111”
输出:0
解释:除了空子字符串之外不存在其他平衡子字符串,所以答案为 0 。
提示:
1 <= s.length <= 50
‘0’ <= s[i] <= ‘1’
🌟 求解思路&实现代码&运行结果
⚡ 模拟
🥦 求解思路
- 通过题目的意思,我们直接模拟遍历即可,找到所有的 0 都在 1 之前且其中 0 的数量等于 1 的数量的最长平衡子字符串,返回最终的长度即可。
- 具体实现代码如下所示:
🥦 实现代码
class Solution {
public int findTheLongestBalancedSubstring(String s) {
int ans=0;
int n=s.length();
int i=0;
while(i<n){
int c0=0,c1=0;
while(i<n&&s.charAt(i)=='0'){
c0++;
i++;
}
while(i<n&&s.charAt(i)=='1'){
c1++;
i++;
}
ans=Math.max(ans,2*Math.min(c0,c1));
}
return ans;
}
}
🥦 运行结果
💬 共勉
最后,我想和大家分享一句一直激励我的座右铭,希望可以与大家共勉! |