滑动窗口9.23

news2024/11/24 19:39:34

1876.长度为3且各字符不同的子字符串

1876. 长度为三且各字符不同的子字符串 - 力扣(LeetCode)icon-default.png?t=N7T8https://leetcode.cn/problems/substrings-of-size-three-with-distinct-characters/?envType=list&envId=24zW97w8自写思路:
数组充当哈希表,只要当前窗口等于3判断该数组中是否有某处值大于1,如果有则说明某一个字母连续出现两次。
如果没有则使res自增,每次循环时会自动删掉第一个数然后放新数进来
一开始是想用unordered set去写,后来写完了才想起来这个set无法存相同的字符

子字符串是连续的,不要忘记这一点,所以这也是使用滑动窗口约束字符串的原因

这道题固定了窗口大小,并且很明显的判断子串是否各不相同是应用哈希表来查重,属于哈希和窗口搭配的模板题了,虽然简单不过可以多看几遍熟练掌握

class Solution {
public:
    int countGoodSubstrings(string s) {
        int arr[26]={0};
        int res=0;
        for(int i=0;i<s.size();i++){
            if(i>2)arr[s[i-3]-'a']--;
            arr[s[i]-'a']++;
            if(fun(arr)&&i>=2)res++;
        }
        return res;
    }
    bool fun(int *arr){
        for(int i=0;i<26;++i)
        if(arr[i]>1)return false;
        return true;
    }
};

这是一道暴力求解貌似比滑动窗口效率要高的题,官方提供的是暴力求解的方法

class Solution {
public:
    int countGoodSubstrings(string s) {
        int res = 0;
        int n = s.size();
        for (int i = 0; i < n - 2; ++i){
            if (s[i] != s[i+1] && s[i] != s[i+2] && s[i+1] != s[i+2]){
                ++res;
            }
        }
        return res;
    }
};

 用滑动窗口空间是ON,而暴力是O1,时间都一样


1984.学生分数的最小差值

1984. 学生分数的最小差值 - 力扣(LeetCode)icon-default.png?t=N7T8https://leetcode.cn/problems/minimum-difference-between-highest-and-lowest-of-k-scores/?envType=list&envId=24zW97w8

这道题相当于k就是窗口大小,求窗口内最大值和最小值的差然后比较谁最小,但是,前提是得排序,如果你不排序,你将无法确定窗口的大小是多少,它是一个不确定的数
因为数据杂乱无章,以题给例子为例,这个例子里能减出最小值的两个数是在该数组的最左和最右,那你就得不停扩大窗口,试探性找本次最小差

这也就相当于把窗口大小看成是数组的总大小,通过有规律的使k个数相减,通过循环来控制,以求得最小值,看上去好像可行,但是如果k不是2呢?
你要同时控制多重k循环,来使相减数有规律的往后推,以保证不要落下任何可能的值,实际上这是无法做到的。

说完了排序的必要,还要说一下,这个循环的必要
一开始没有看懂,觉得这已经排完序了,那你就直接用nums【i+k-1】-nums【i】不就完事了?但是它确实不一定是最小的数
比如说这个排完序的数组【0,9,12,13】它不一定就是最后一个数往前减就大!
虽然题目说的是任意取k个,但是我们已经排完序了,所以把它看成是在窗口里取数,不然排序的意义何在?
 

这道题也是窗口的一个应用,自己没有做出来,一开始找窗口范围,发现是无法求得窗口的范围的,这让我犯了难,看了题解发现,将数组排序就可以用已给条件k来确定了

如果对于可以进行排序并且感觉可以用窗口做的题,不妨试一下排序,问题就会迎刃而解

class Solution {
public:
    int minimumDifference(vector<int>& nums, int k) {
        sort(nums.begin(),nums.end());int res=INT_MAX;
        for(int i=0;i<=nums.size()-k;++i){
            res=min(res,nums[i+k-1]-nums[i]);
        }
        return res;
    }
};

2269.找到一个数字的K美丽值

2269. 找到一个数字的 K 美丽值 - 力扣(LeetCode)icon-default.png?t=N7T8https://leetcode.cn/problems/find-the-k-beauty-of-a-number/?envType=list&envId=24zW97w8把数字num转化为字符串,进入循环使i一直指向窗口末端,使用i-k+1定位窗口左端,窗口大小恒定为k,截取该窗口字符串转化为数字若该数字不为0且可以被整除,则res自增

这道题很简单,没什么要讲的,就是用窗口确定该次要判断的字符串长度,然后将其转为数字再进行整除运算,如果能整除则res++,挨个窗口往后走即可。

代码也是十分的简单

class Solution {
public:
    int divisorSubstrings(int num, int k) {
        string s=to_string(num);int res=0;
        for(int i=k-1;i<s.size();i++){
            int sum=stoi(s.substr(i-k+1,k));
            if(sum&&num%sum==0)res++;
        }
        return res;
    }
};

下一期我们更新哈希表,如果对你有帮助请给个三连支持一下哦!

想看更多的算法题解或者数据结构也可以查看往期的文章,如果你有想看的也可以在评论区进行讨论

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1034496.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Spring面试题16:Spring框架中的单例bean是线程安全的吗?Spring框架中bean的生命周期?哪些是重要的bean生命周期方法?

该文章专注于面试,面试只要回答关键点即可,不需要对框架有非常深入的回答,如果你想应付面试,是足够了,抓住关键点 面试官:Spring框架中的单例bean是线程安全的吗?为什么? 是的,Spring框架中的单例Bean是线程安全的。 Spring中的单例Bean默认是在容器启动时创建的,并…

【Cpp】位图Bitmap

code #include <iostream> #include <vector> #include <stdio.h> #include <stdint.h>class Bitmap { private:std::vector<uint8_t> data; // 存储位图数据的字节数组uint32_t size; // 位图的大小&#xff08;以位为单位&#x…

springboot整合aop,实现日志操作

前言&#xff1a; 整合之前&#xff0c;我们要明白aop是什么&#xff0c;为什么要用aop&#xff0c;aop能帮我们做什么。 答&#xff1a;AOP是面向切面编程&#xff08;Aspect-Oriented Programming&#xff09;的简称&#xff0c;它是一种编程思想&#xff0c;旨在在面向对象…

【AI视野·今日Sound 声学论文速览 第十期】Fri, 22 Sep 2023

AI视野今日CS.Sound 声学论文速览 Fri, 22 Sep 2023 Totally 1 papers &#x1f449;上期速览✈更多精彩请移步主页 Daily Sound Papers Performance Conditioning for Diffusion-Based Multi-Instrument Music Synthesis Authors Ben Maman, Johannes Zeitler, Meinard M lle…

数据库中的DDL与DML

标签&#xff1a;数据库 记录下DDL和DML的相关概念。 数据定义语言 定义数据库模式 数据定义语言DDL(Data-Definition Language)可定义数据库模式。数据库模式在之前的文章中已经提到过了。简单来说&#xff0c;建表用的SQL语句就是DDL。如下代码 CREATE TABLE department(de…

使用Python做一个微信机器人

介绍 简介 该程序将微信的内部功能提取出来&#xff0c;然后在程序里加载Python&#xff0c;接着将这些功能导出成库函数&#xff0c;就可以在Python里使用这些函数 程序启动的时候会执行py_code目录下的main.py&#xff0c;类似于你在命令行使用python main.py。 现在会以…

用《斗破苍穹》的视角打开C#多线程开发1(斗帝之路)

Thread.Start() 是的&#xff0c;我就是乌坦城那个斗之气三段的落魄少爷&#xff0c;在我捡到那个色眯眯的老爷爷后&#xff0c;斗气终于开始增长了。在各种软磨硬泡下&#xff0c;我终于学会了我人生中的第一个黄阶斗技——吸掌。 using System.Threading;namespace Framewo…

第一部分:HTML5

一&#xff1a;网页 1.1&#xff1a;什么是网页&#xff1f; 网站是指在因特网上根据一定的规则&#xff0c;使用HTML等制作的用于展示特定内容相关的网页集合 网页是网站中的一"页"&#xff0c;通常是HTML格式的文件&#xff0c;它要通过浏览器来阅读 网页是构成网…

透视俄乌网络战之四:西方科技巨头的力量

透视俄乌网络战之一&#xff1a;数据擦除软件 透视俄乌网络战之二&#xff1a;Conti勒索软件集团&#xff08;上&#xff09; 透视俄乌网络战之三&#xff1a;Conti勒索软件集团&#xff08;下&#xff09; 西方科技巨头的力量 1. Palantir2. SpaceX3. Maxar Technologies4. Cl…

送水订水小程序商城的作用是什么?

桶/瓶装水有很高的市场需求度&#xff0c;除了家庭外&#xff0c;部分办公场几乎每天都会订水且有一定的合作&#xff0c;由于没有空间限制&#xff0c;因此对桶装水商家来说&#xff0c;本地和外地客户都有较高的拓展度&#xff0c;而传统电话、微信私信订购宣传方式低效且不智…

10.5 串联型稳压电路(1)

稳压管稳压电路输出电流较小&#xff0c;输出电压不可调&#xff0c;不能满足很多场合下的应用。串联型稳压电路以稳压管稳压电路为基础&#xff0c;利用晶体管的电流放大作用&#xff0c;增大负载电流&#xff1b;在电路中引入深度电压负反馈使输出电压稳定&#xff1b;并且&a…

ElasticSearch - 分布式搜索引擎底层实现——倒排索引

目录 一、ElasticSearch 1.1、ElasticSearch 是什么&#xff1f; 1.2、ElasticStack 是什么? 1.3、正向索引和倒排索引 1.3.1、正向索引 1.3.2、倒排索引 a&#xff09;倒排索引的创建过程&#xff1a; b&#xff09;倒排索引的查询过程&#xff1a; c&#xff09;分…

三、初识FreeRTOS之FreeRTOS基础知识

从这节开始&#xff0c;我们正式学习FreeRTOS的一些基础知识&#xff0c;争取做到日更&#xff0c;或者隔日更。如果在学习的过程中哪里有理解错误&#xff0c;希望各位朋友批评指正。因为自己觉得图文并茂好像更容易理解一点&#xff0c;所以在博文中加了大量的图片&#xff0…

Tomcat部署、优化、以及操作练习

一.Tomcat的基本介绍 1.1.Tomcat是什么&#xff1f; Tomcat服务器是一个免费的开放源代码的Web应用服务器&#xff0c;属于轻量级应用服务器&#xff0c;在中小型系统和并发访问用户不是很多的场合下被普遍使用&#xff0c;是开发和调试JSP程序的首选。一般来说&#xff0c;T…

APM32F0XX/STM32F0XX内部参考电压VREFINT反算ADC引脚电压

首先打开极海APM32F030x4x6x8xC 用户手册找到VREFINT。 找到内部参考电压 VREFINT为ADC1_IN17通道 使用VREFINT必须使能VREFEN位 初始化ADC代码 void ADC_Init(void) {GPIO_Config_T gpioConfig;ADC_Config_T adcConfig;/* Enable GPIOA clock */RCM_Ena…

Redis学习笔记--002

Redis的JAVA客户端 文章目录 Redis的JAVA客户端一、Redis的Java客户端的种类二、Jedis2.1、使用步骤2.2、Jedis连接池 三、[SpringDataRedis](https://spring.io/projects/spring-data-redis)3.1、介绍3.2、RedisTemplate3.3、SpringDataRedis使用步骤3.4、SpringDataRedis的序…

银行家算法——C语言实现

算法思路 将操作系统看作是银行家&#xff0c;操作系统所拥有的资源就相当于银行家所拥有的资产&#xff0c;进程向操作系统申请资源就相当于资产家向银行贷款&#xff0c;规定资产家在向银行贷款之前&#xff0c;先申明其所贷数额的最大值&#xff0c;申明之后其贷款的数额不…

深度学习-一个简单的深度学习推导

文章目录 前言1.sigmod函数2.sigmoid求导3.损失函数loss4.神经网络1.神经网络结构2.公式表示-正向传播3.梯度计算1.Loss 函数2.梯度1.反向传播第2-3层2.反向传播第1-2层 前言 本章主要推导一个简单的两层神经网络。 其中公式入口【入口】 1.sigmod函数 激活函数我们选择sigmo…

银河麒麟ky10 server sp3下载

下载路径 /操作系统/Kylin-Server-V10-SP3-General-Release-2212-X86_64.iso

(高阶) Redis 7 第15讲 布隆过滤器 BitMap篇

面试题 如何快速准备判断某一数据在海量数据中存在了解布隆过滤器吗安全网址判断,黑名单校验,识别垃圾邮件白名单校验,识别合法用户?理论 由一个初始值都为0的 bit数组和多个哈希函数构成,用来快速判断集合中是否存在某个元素 设计思想 目的减少内存占用方式不保存数据信…