滑动窗口9.23

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.mzph.cn/news/86363.shtml

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

相关文章

qemu+docker在服务器上搭建linux内核调试环境

基于docker和qemu的操作系统实验环境 参考以上文章实现。 其中 docker run -it --name linux_qemu qemu /bin/bash #从qemu镜像启动一个容器linux_qemu,进入shell 要改为 docker run -it --name linux_qemu 3292900173/qemu /bin/bash另外&#xff0c;在vscode运行过程中,ssh远…

useCallBack

React.memo 保证了只有props发生变化时&#xff0c;该组件才会重新渲染 &#xff08;当然组件内部的state 和 context 变化也会导致组件重新渲染&#xff09;&#xff0c;但咱们只要将咱们的子组件包裹&#xff0c;便可以保证Child组件在props不变的情况下&#xff0c;不会重新…

795. 区间子数组个数

795. 区间子数组个数 给你一个整数数组 nums 和两个整数&#xff1a;left 及 right 。找出 nums 中连续、非空且其中最大元素在范围 [left, right] 内的子数组&#xff0c;并返回满足条件的子数组的个数。 生成的测试用例保证结果符合 32-bit 整数范围。 示例 1&#xff1a;…

【C语言】指针经典笔试题(上)

C语言的一大重头戏就是指针。 对于指针有一些认识&#xff1a; 1.指针是存放变量的地址&#xff0c;一般说的指针和指针变量是一个概念。 2.地址的单位是字节&#xff0c;大小在不同编译器环境下有所不同&#xff0c;32位机器是4个字节&#xff0c;64位机器是8个字节。 3.数组名…

错误处理函数 / 模板上下文处理函数

app.errorhandler(404) # 传入要处理的错误代码 def page_not_found(e): # 接受异常对象作为参数user User.query.first()return render_template(404.html, useruser), 404 # 返回模板和状态码对于多个模板内都需要使用的变量&#xff0c;我们可以使用 app.context_proces…

学会使用Git 和 GitHub

Git 和 GitHub 都是程序员每天都要用到的东西 —— 前者是目前最先进的 版本控制工具&#xff0c;拥有最多的用户&#xff0c;且管理着地球上最庞大的代码仓库&#xff1b;而后者是全球最大 同性交友 代码托管平台、开源社区。 在没有这两个工具时&#xff0c;编程可能是这样的…

Floyd算法基础

弗洛伊德算法(Floyd) 之前介绍了迪杰斯特拉算法(Dijkstra)。具体请看&#xff1a;最短路径算法——简单明了的迪杰斯特拉算法(Dijkstra)。Dijkstra适用于非负权图&#xff0c;并且一次只能从网络中找源点到任何一个节点的最短路径&#xff0c;而Floyd算法的应用更加广泛&#…

【C刷题】day3

一、选择题 1、已知函数的原型是&#xff1a; int fun(char b[10], int *a); &#xff0c;设定义&#xff1a; char c[10];int d; &#xff0c;正确的调用语句是&#xff08; &#xff09; A: fun(c,&d); B: fun(c,d); C: fun(&c,&d); D: fun(&c,d); 【答案…

正则表达式新解

文章目录 是什么&#xff1f;正则用法匹配单个字符匹配一组字符其他元字符核心函数 贪婪匹配和非贪婪匹配正则练习 是什么&#xff1f; 正则表达式(Regular Expression)是一种文本模式&#xff0c;包括普通字符&#xff08;例如&#xff0c;a 到 z 之间的字母&#xff09;和特殊…

MySQL列大小写敏感

一、背景知识 字符集COLLATE 1、字符集是一套符号和编码&#xff0c;COLLATE是在字符集内用于比较字符的一套规则。通常的字符集都是utf8mb4&#xff08;8.0默认&#xff09;。 2、在mysql中&#xff0c;字符类型的列&#xff0c;比如&#xff1a;char、text、varchar等类型…

算法leetcode|83. 删除排序链表中的重复元素(rust重拳出击)

文章目录 83. 删除排序链表中的重复元素&#xff1a;样例 1&#xff1a;样例 2&#xff1a;提示&#xff1a; 分析&#xff1a;题解&#xff1a;rust&#xff1a;go&#xff1a;c&#xff1a;python&#xff1a;java&#xff1a; 83. 删除排序链表中的重复元素&#xff1a; 给…

ChatGLM GPT原理介绍

图解GPT 除了BERT以外,另一个预训练模型GPT也给NLP领域带来了不少轰动,本节也对GPT做一个详细的讲解。 OpenAI提出的GPT-2模型(https://openai.com/blog/better-language-models/) 能够写出连贯并且高质量的文章,比之前语言模型效果好很多。GPT-2是基于Transformer搭建的,相…

注解,自定义注解

一、什么是注解 二、自定义注解 /*** 自定义注解*/public interface MyAnnotation {String aaa();boolean bbb() default true;String ccc(); }MyAnnotation ( aaa "牛魔王",ccc "sss") public class Test {MyAnnotation ( aaa "aaa",ccc &q…

vue 使用cornerstone解析 .dcm 文件

// 首先下载依赖 npm install --save cornerstone-core cornerstone-math cornerstone-tools hammerjs cornerstone-web-image-loader 下载之后再package.json中可以看到最后图片的依赖// 下面是完成的组件代码 <template><div id"dicom_canvas" refdicom_c…

第75步 时间序列建模实战:多步滚动预测 vol-3(以决策树回归为例)

基于WIN10的64位系统演示 一、写在前面 上两期&#xff0c;我们讲了多步滚动预测的第两种策略&#xff1a; 对于重复的预测值&#xff0c;取平均处理。例如&#xff0c;&#xff08;1,2,3&#xff09;预测出3.9和4.5&#xff0c;&#xff08;2,3,4&#xff09;预测出5.2和6.…

物联网的未来:连接的智能世界

物联网&#xff08;IoT&#xff09;是引领我们走向未来的一项关键技术。它让物品通过互联网进行连接&#xff0c;交流&#xff0c;开创了智能生活新时代。预计到2025年&#xff0c;全球将拥有超过410亿的IoT设备。在对人类生活的每个方面产生影响的同时&#xff0c;物联网也正在…

【ardunio】青少年机器人四级实操代码(2023年9月)

目录 一、题目 &#xff08;一&#xff09;试题原题 &#xff08;二&#xff09;试题解读 1、欢迎区和欢送区范围 &#xff08;1&#xff09;符合习惯 &#xff08;2&#xff09;以门为参考点会有不反应区 &#xff08;3&#xff09;以门为参考点门里门外不反应区不对称…

virtualbox配置ubuntu1804虚拟机相关流程

virtualbox配置ubuntu1804虚拟机相关流程 相关版本能解决的问题安装流程1&#xff1a;新建虚拟机安装流程2&#xff1a;配置虚拟机安装流程3&#xff1a;安装虚拟机系统安装流程4&#xff1a;设置ubuntu 相关版本 virtualbox使用VirtualBox官网下载的6.1.34 r150636 版。ubunt…

2023年Android Gradle、Gradle插件以及Kotlin版本升级记录

Compose和kotlin版本对应关系&#xff1a;https://androidx.dev/storage/compose-compiler/repository gradle版本和gradle插件版本对应关系&#xff1a; https://developer.android.google.cn/studio/releases/gradle-plugin?hlzh-cn gradle最新版本在这里找&#xff1a;http…

面试题 05.02. 二进制数转字符串

面试题 05.02. 二进制数转字符串 二进制数转字符串。给定一个介于0和1之间的实数&#xff08;如0.72&#xff09;&#xff0c;类型为double&#xff0c;打印它的二进制表达式。如果该数字无法精确地用32位以内的二进制表示&#xff0c;则打印“ERROR”。 示例1: 输入&#x…