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;
    }
}
相关推荐
专注数据的痴汉1 分钟前
「数据获取」全国民用运输机场吞吐量排名(2006-2024)
java·大数据·服务器·数据库·信息可视化
木卫二号Coding11 分钟前
Python-文件拷贝+文件重命名+shutil+记录
开发语言·python
leaves falling11 分钟前
冒泡排序(基础版+通用版)
数据结构·算法·排序算法
老鼠只爱大米16 分钟前
LeetCode算法题详解 56:合并区间
leetcode·并查集·合并区间·区间合并·线性扫描·算法面试
悟空码字27 分钟前
无缝集成指南,SpringBoot三步接入华为云短信服务
java·springboot·编程技术·后端开发·华为云短信
bubiyoushang88829 分钟前
基于Q-learning的路径规划MATLAB仿真程序实现
开发语言·matlab
E_ICEBLUE33 分钟前
【2026 最新教程】Java 自动化提取 PDF 表格:从文本到 Excel/CSV 的全场景实现
java·pdf·自动化
C雨后彩虹34 分钟前
无向图染色
java·数据结构·算法·华为·面试
J_HelloWorld36 分钟前
缺页中断:Java高性能存储的隐形推手
java·缺页中断
FAFU_kyp39 分钟前
Rust 结构体(struct)
开发语言·后端·rust