码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 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)

    1. class Solution {
    2. public int secondsToRemoveOccurrences(String s) {
    3. int n = s.length();
    4. int ans = 0;
    5. for(int i=0,cnt=0;i < n; i++){
    6. if(s.charAt(i)=='0')++cnt;
    7. else if(cnt>0) ans = Math.max(ans+1,cnt);
    8. }
    9. return ans;
    10. }
    11. }

  • 相关阅读:
    传感器_三相-双极性-开关型-霍尔传感器 速度+电角度解算理解
    TypeScript(基础篇)day01
    回到街头 - 数字时尚嘉年华:Web3的时尚未来,4月香港兰桂坊盛大启幕
    怎样给视频添加自定义的封面
    web应用及微信小程序版本更新检测方案实践
    消息推送平台的实时数仓?!flink消费kafka消息入到hive
    PHP利用jsonp跨域实现
    Ubuntu记录
    1.4_16 Axure RP 9 for mac 高保真原型图 - 案例15 【动态面板-滚动条5】深色模式 - 按钮效果升级
    C++ Reference: Standard C++ Library reference: Containers: deque: deque: erase
  • 原文地址:https://blog.csdn.net/yu_duan_hun/article/details/126492851
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号