C.滑动窗口-越长越合法/求最短/最小——2904. 最短且字典序最小的美丽子字符串

题目链接:2904. 最短且字典序最小的美丽子字符串(中等)

算法原理:

👉对应力扣题解

解法:滑动窗口

击败81.74%

时间复杂度O(N)

①先判断是否有解,无解直接返回空串

②进窗口:计数器++

③出窗口:尽可能缩小长度,因为前面是'0'也要缩小长度,所以先出窗口

④更新:对比要返回的字符串和当前的字符串,如果当前字符串长度小,直接更新,或者长度相同时字典序更小,再更新

Java代码:

java 复制代码
class Solution {
    public String shortestBeautifulSubstring(String ss, int k) {
        //先统计1的个数,无解直接返回空串
        int one=0;
        char[] s=ss.toCharArray();
        for(char c:s) if(c=='1') one++;
        if(one<k) return "";
        int n=s.length,count=0;
        int len=n;
        String ret=ss;
        for(int right=0,left=0;right<n;right++){
            //进窗口
            if(s[right]=='1') count++;
            //出窗口
            while(count>k||s[left]=='0')
                if(s[left++]=='1') count--;
            //更新
            if(count==k){
                //[left,right+1)->[left,right]
                String t=ss.substring(left,right+1);
                //长度更小或者字典序更小就更新
                if(t.length()<ret.length()||t.length()==ret.length()&&t.compareTo(ret)<0)
                    ret=t;
            }
        }
        return ret;
    }
}
相关推荐
不吃土豆的马铃薯2 分钟前
Spdlog 入门:日志记录器与日志槽基础详解
服务器·开发语言·c++·c·日志·spdlog
此生决int6 分钟前
算法从入门到精通——前缀和
c++·算法·蓝桥杯
AI瓦力7 分钟前
技术分享 | 彻底解决图片“躺平”问题:Java 后端强制校准图片方向
java
武子康9 分钟前
Java-219 RocketMQ Spring Boot 集成指南:生产者与消费者实战
java·spring boot·分布式·kafka·消息队列·rocketmq·java-rocketmq
凯瑟琳.奥古斯特10 分钟前
传输层核心功能解析
开发语言·网络·职场和发展
我星期八休息11 分钟前
Linux系统编程—库制作与原理
linux·运维·服务器·数据结构·人工智能·python·散列表
RainCityLucky14 分钟前
Java Swing 自定义组件库分享(七)
java·笔记·后端
大大杰哥22 分钟前
leetcode hot100(4)矩阵
算法·leetcode·矩阵
Fuyo_111926 分钟前
C++中的活字印刷术——模板·初阶
开发语言·c++·笔记
小白|26 分钟前
cmake:昇腾CANN构建系统完全指南
java·c++·算法