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;
    }
}
相关推荐
洛水水11 小时前
【力扣100题】76.搜索插入位置
数据结构·算法·leetcode
Techblog of HaoWANG11 小时前
智巡守卫:多模态巡检智能体算法服务端设计与实现——基于Ollama+Qwen3.5的自动化巡检报告生成系统
运维·人工智能·算法·目标检测·自动化·边缘计算
伊灵eLing11 小时前
GoLang 语言基础
开发语言·后端·golang
两年半的个人练习生^_^11 小时前
JMM 进阶:彻底理解 synchronized 实现原理
java·开发语言
小白不白11111 小时前
Invoke的用法
开发语言·人工智能·数码相机·计算机视觉·c#
techdashen11 小时前
What is maintenance, anyway?
开发语言·后端·rust
戳代码的新星11 小时前
论小白如何学会使用Maven
java·maven
wyhwust11 小时前
maven的安装和配置
java
万法若空11 小时前
C/C++基本类型表示范围
c语言·开发语言·c++
小蒋学算法11 小时前
算法-灌溉花园的最少龙头数目-贪心
算法