微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

2380. 二进制字符串重新安排顺序需要的时间 贪心

2380. 二进制字符串重新安排顺序需要的时间 

给你一个二进制字符串 s 。在一秒之中,所有 子字符串 "01" 同时 被替换成 "10" 。这个过程持续进行到没有 "01" 存在。

请你返回完成这个过程所需要的秒数。

示例 1:

输入:s = "0110101"
输出4
解释:
一秒后,s 变成 "1011010" 。
再过 1 秒后,s 变成 "1101100" 。
第三秒过后,s 变成 "1110100" 。
第四秒后,s 变成 "1111000" 。
此时没有 "01" 存在,整个过程花费 4 秒。
所以我们返回 4 。

示例 2:

输入:s = "11100"
输出0
解释:
s 中没有 "01" 存在,整个过程花费 0 秒。
所以我们返回 0 。

提示

  • 1 <= s.length <= 1000
  • s[i] 要么是 '0' ,要么是 '1' 。

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/time-needed-to-rearrange-a-binary-string
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

做题结果

比赛时虽然成功,但是没想出O(n)写法,记录此篇用于学习O(n)写法

 方法:贪心

1. 遇到0,说明如果后面再遇到1,需要多挪动一位(++zeroCnt)

2. 遇到1,假设前面所有1都靠左边(zeroCnt=0),不用挪动 111000

3. 遇到两个11,前面有0,比如011,则需要第一个1左移,变成101,之后第二个1才可以移动,也就是说后面的1至少比前面的1多移动一步 max(dp+1,zeroCnt)

class Solution {
    public int secondsToRemoveOccurrences(String s) {
        int n = s.length();
        int ans = 0;
        for(int i=0,cnt=0;i < n; i++){
            if(s.charat(i)=='0')++cnt;
            else if(cnt>0) ans = Math.max(ans+1,cnt);
        }
        return ans;
    }
}

原文地址:https://www.jb51.cc/wenti/3287714.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐