【算法模板】基础:尺取法

2024-08-27 14:04
文章标签 算法 基础 模板 取法

本文主要是介绍【算法模板】基础:尺取法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

尺取法(Sliding Window Technique),也叫滑动窗口法,是一种常见的算法思想,主要用于在一维数组或字符串中寻找满足某种条件的子数组或子串。它的核心思想是通过维护一个可变的窗口来遍历数组或字符串,从而有效地减少问题的时间复杂度。

算法思想

尺取法的核心思想是:

  1. 维护一个窗口:在数组或字符串上维护一个固定或可变的窗口,这个窗口可以看作是两个指针(通常是 leftright),用来表示当前关注的子数组或子串。
  2. 扩大或缩小窗口:通过移动 right 指针来扩大窗口的右边界,通过移动 left 指针来缩小窗口的左边界,从而动态调整窗口的大小。
  3. 检查窗口内容:在每次调整窗口时,检查当前窗口是否满足问题的条件。如果满足,则记录或进一步处理;如果不满足,则继续调整窗口的大小或位置。

算法流程

以在数组中寻找和为某个目标值的最短子数组为例,尺取法的算法流程如下:

  1. 初始化
    • 定义两个指针 leftright,都指向数组的起始位置。
    • 定义一个变量 current_sum 来存储当前窗口内元素的和。
    • 定义一个变量 min_length 来存储最短子数组的长度,初始值设置为正无穷大。
  2. 移动右指针
    • 逐步移动 right 指针,将 right 指向的元素加入 current_sum 中。
    • 每次移动后,检查 current_sum 是否大于或等于目标值。如果是,则尝试缩小窗口。
  3. 移动左指针
    • current_sum 大于或等于目标值时,逐步移动 left 指针,将 left 指向的元素从 current_sum 中移除。
    • 每次移动后,检查 current_sum 是否仍然大于或等于目标值。如果是,则继续缩小窗口,并更新 min_length
    • 如果 current_sum 小于目标值,则停止移动 left 指针,并回到移动 right 指针的步骤。
  4. 结束
    • right 指针遍历完整个数组后,算法结束。如果 min_length 仍为正无穷大,说明不存在满足条件的子数组;否则,返回 min_length 作为结果。

例题

字符串 (nowcoder.com)

小N现在有一个字符串S。他把这这个字符串的所有子串都挑了出来。一个S的子串T是合法的,当且仅当T中包含了所有的小写字母。小N希望知道所有的合法的S的子串中,长度最短是多少。

#include <bits/stdc++.h>
using namespace std;int main(){string s;cin>>s;const int n=s.size();int ans=0;for(int i=0;i<n;i++){while(i<n and not islower(s[i]))i++;int len=1;while(i+len<n and islower(s[i+len]))len++;i+=len-1;ans=max(ans,len);}cout<<ans<<endl;return 0;
}

丢手绢 (nowcoder.com)

“丢丢手绢,轻轻地放在小朋友的后面,大家不要告诉她,快点快点抓住她,快点快点抓住她。”牛客幼儿园的小朋友们围成了一个圆圈准备玩丢手绢的游戏,但是小朋友们太小了,不能围成一个均匀的圆圈,即每个小朋友的间隔可能会不一致。为了大家能够愉快的玩耍,我们需要知道离得最远的两个小朋友离得有多远(如果太远的话牛老师就要来帮忙调整队形啦!)。

因为是玩丢手绢,所以小朋友只能沿着圆圈外围跑,所以我们定义两个小朋友的距离为沿着圆圈顺时针走或者逆时针走的最近距离。

#include <bits/stdc++.h>
using namespace std;int main() {int n;cin >> n;vector<int> v(n);for (int &i : v) cin >> i;int sum = accumulate(v.begin(), v.end(), 0);int l = 0, r = 0, s = 0;int ans = 0;for(int l = 0,r=0;l < n; l++){while(s < sum/2)s+=v[(r++)%n];ans=max(ans,min(sum-s,s));s-=v[l];}cout << ans << endl;return 0;
}

这篇关于【算法模板】基础:尺取法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1111876

相关文章

Java利用Spire.Doc for Java实现在模板的基础上创建Word文档

《Java利用Spire.DocforJava实现在模板的基础上创建Word文档》在日常开发中,我们经常需要根据特定数据动态生成Word文档,本文将深入探讨如何利用强大的Java库Spire.Do... 目录1. Spire.Doc for Java 库介绍与安装特点与优势Maven 依赖配置2. 通过替换

JavaScript装饰器从基础到实战教程

《JavaScript装饰器从基础到实战教程》装饰器是js中一种声明式语法特性,用于在不修改原始代码的情况下,动态扩展类、方法、属性或参数的行为,本文将从基础概念入手,逐步讲解装饰器的类型、用法、进阶... 目录一、装饰器基础概念1.1 什么是装饰器?1.2 装饰器的语法1.3 装饰器的执行时机二、装饰器的

Java JAR 启动内存参数配置指南(从基础设置到性能优化)

《JavaJAR启动内存参数配置指南(从基础设置到性能优化)》在启动Java可执行JAR文件时,合理配置JVM内存参数是保障应用稳定性和性能的关键,本文将系统讲解如何通过命令行参数、环境变量等方式... 目录一、核心内存参数详解1.1 堆内存配置1.2 元空间配置(MetASPace)1.3 线程栈配置1.

Python实现Word文档自动化的操作大全(批量生成、模板填充与内容修改)

《Python实现Word文档自动化的操作大全(批量生成、模板填充与内容修改)》在职场中,Word文档是公认的好伙伴,但你有没有被它折磨过?批量生成合同、制作报告以及发放证书/通知等等,这些重复、低效... 目录重复性文档制作,手动填充模板,效率低下还易错1.python-docx入门:Word文档的“瑞士

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

使用Java填充Word模板的操作指南

《使用Java填充Word模板的操作指南》本文介绍了Java填充Word模板的实现方法,包括文本、列表和复选框的填充,首先通过Word域功能设置模板变量,然后使用poi-tl、aspose-words... 目录前言一、设置word模板普通字段列表字段复选框二、代码1. 引入POM2. 模板放入项目3.代码

Spring的基础事务注解@Transactional作用解读

《Spring的基础事务注解@Transactional作用解读》文章介绍了Spring框架中的事务管理,核心注解@Transactional用于声明事务,支持传播机制、隔离级别等配置,结合@Tran... 目录一、事务管理基础1.1 Spring事务的核心注解1.2 注解属性详解1.3 实现原理二、事务事

Python进行word模板内容替换的实现示例

《Python进行word模板内容替换的实现示例》本文介绍了使用Python自动化处理Word模板文档的常用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友... 目录技术背景与需求场景核心工具库介绍1.获取你的word模板内容2.正常文本内容的替换3.表格内容的

Java中最全最基础的IO流概述和简介案例分析

《Java中最全最基础的IO流概述和简介案例分析》JavaIO流用于程序与外部设备的数据交互,分为字节流(InputStream/OutputStream)和字符流(Reader/Writer),处理... 目录IO流简介IO是什么应用场景IO流的分类流的超类类型字节文件流应用简介核心API文件输出流应用文