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 分钟前
leetcode 121.买卖股票的最佳时机
算法·leetcode·职场和发展
CoovallyAIHub4 分钟前
不需要Memory Bank:CMDR-IAD用2D+3D双分支重建做工业异常检测,MVTec 3D 97.3%
算法·架构·github
被摘下的星星5 分钟前
Go赋值操作的关键细节
开发语言·golang
计算机学姐6 分钟前
基于SpringBoot的在线学习网站平台【个性化推荐+数据可视化+课程章节学习】
java·vue.js·spring boot·后端·学习·mysql·信息可视化
jwn9996 分钟前
Laravel2.x经典特性回顾
开发语言·php·laravel
焦糖玛奇朵婷10 分钟前
盲盒小程序开发,盲盒小程序怎么做
java·大数据·服务器·前端·小程序
喵了几个咪12 分钟前
Go 语言 CMS 横评:风行 GoWind 对比传统 PHP/Java CMS 核心优势
java·golang·php
TE-茶叶蛋14 分钟前
使用FlyEnv启动PHP项目
开发语言·php
AI科技星15 分钟前
基于四维速率恒为c公设的北斗GEO卫星昼夜钟差模型修正与实测验证
开发语言·人工智能·线性代数·算法·数学建模
星晨雪海15 分钟前
Spring Boot 常用注解
java·spring boot·后端