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;
    }
}
相关推荐
smj2302_796826523 分钟前
解决leetcode第3911题.移除子数组元素后第k小偶数
数据结构·python·算法·leetcode
山甫aa22 分钟前
差分数组 ----- 从零开始的数据结构
数据结构
早日退休!!!31 分钟前
《数据结构选型指南》笔记
数据结构·数据库·oracle
九转成圣1 小时前
Java 性能优化实战:如何将海量扁平数据高效转化为类目字典树?
java·开发语言·json
Beginner x_u1 小时前
链表专题:JS 实现原理与高频算法题总结
javascript·算法·链表
SmartRadio1 小时前
ESP32-S3 双模式切换实现:兼顾手机_路由器连接与WiFi长距离通信
开发语言·网络·智能手机·esp32·长距离wifi
丑八怪大丑1 小时前
Java数据结构与集合源码
数据结构
laowangpython1 小时前
Rust 入门:GitHub 热门内存安全编程语言
开发语言·其他·rust·github
我叫汪枫1 小时前
在后台管理系统中,如何递归和选择保留的思路来过滤菜单
开发语言·javascript·node.js·ecmascript
_.Switch1 小时前
东方财富股票数据JS逆向:secids字段和AES加密实战
开发语言·前端·javascript·网络·爬虫·python·ecmascript