滑动窗口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.rhkb.cn/news/140129.html

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

相关文章

Mysql004:用户管理

前言&#xff1a;本章节讲解的是mysql中的用户管理&#xff0c;包括&#xff08;管理数据用户&#xff09;、&#xff08;控制数据库的访问权限&#xff09;。 目录 1. 查询用户 2. 创建用户 3. 修改用户密码 4. 删除用户 5. 权限控制 1. 查询用户 在mysql数据库中&#xff0…

数字IC设计系列----单端口RAM、双端口RAM

一、单端口RAM原理及实现 1.1、概念/原理 在内存空间中开辟出一段固定大小的内存用于存储数据&#xff0c;每一个数据所占的bit位称之为位宽&#xff0c;这段内存空间中数据的总数称之为深度。例如reg [7:0] mem [255:0]&#xff0c;这段内存空间中每一个数据的位宽为8bit&am…

Nuxt 菜鸟入门学习笔记:路由

文章目录 路由 Routing页面 Pages导航 Navigation路由参数 Route Parameters路由中间件 Route Middleware路由验证 Route Validation Nuxt 官网地址&#xff1a; https://nuxt.com/ 路由 Routing Nuxt 的一个核心功能是文件系统路由器。pages/目录下的每个 Vue 文件都会创建一…

C语言数组和指针笔试题(四)(一定要看)

目录 二维数组例题一例题二例题三例题四例题五例题六例题七例题八例题九例题十例题十一 结果 感谢各位大佬对我的支持,如果我的文章对你有用,欢迎点击以下链接 &#x1f412;&#x1f412;&#x1f412;个人主页 &#x1f978;&#x1f978;&#x1f978;C语言 &#x1f43f;️…

【Unity3D赛车游戏制作】开始界面场景搭建

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 秩沅 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a;Uni…

大模型的最大bug,回答正确率几乎为零,GPT到Llama无一幸免

目录 前言 1.名字和描述颠倒一下&#xff0c;大模型就糊涂了 2.实验及结果 3.未来展望 前言 大模型的逻辑&#xff1f;不存在的。 我让 GPT-3 和 Llama 学会一个简单的知识&#xff1a;A 就是 B&#xff0c;然后反过来问 B 是什么&#xff0c;结果发现 AI 回答的正确率竟然是…

SpringCloud Alibaba - Sentinel

接上文SpringCloud Alibaba - Nacos 1.Sentinel 流量防卫兵 1.1 安装与部署 和Nacos一样&#xff0c;它是独立安装和部署的&#xff0c;下载地址https://github.com/alibaba/Sentinel/releases 下载后的jar放到目录 然后配置 启动并访问,用户名密码都是 sentinel 此时就…

2024年考研教育专业的教育综合考试大纲、样题和往年真题

根据教育部通知&#xff0c;2024年全国硕士研究生招生考试初试定于2023年12月23日至24日&#xff0c;即我们说的2024年考研时间为12月23-24日。距离现在只剩下3个月不到的时间&#xff0c;那么如何让我们在最后三个月内的复习和备考有效且高效呢&#xff1f; 结合很多清北复交研…

湖南麒麟两种修复硬盘方式

1、背景介绍 目前X86平台采用湖南麒麟3.3-3B系统&#xff0c;当遇到文件系统损坏时&#xff0c;可分下面两种情况进行文件系统修复 2、紧急模式下的修复 板子能进入系统&#xff0c;但是进入的是紧急模式&#xff0c;类似下面这种 此时可以直接输入修复命令进行系统修复 xf…

win11 允许使用脚本Set-ExecutionPolicy

目录 Set-ExecutionPolicy RemoteSigned notepad.exe $PROFILE Set-ExecutionPolicy RemoteSigned Set-ExecutionPolicy RemoteSigned 如果报错&#xff0c;执行&#xff1a; Set-ExecutionPolicy -Scope CurrentUser 然后就会提示我们输入&#xff0c;我们把刚刚的 Remot…

C语言每日一题(10):无人生还

文章主题&#xff1a;无人生还&#x1f525;所属专栏&#xff1a;C语言每日一题&#x1f4d7;作者简介&#xff1a;每天不定时更新C语言的小白一枚&#xff0c;记录分享自己每天的所思所想&#x1f604;&#x1f3b6;个人主页&#xff1a;[₽]的个人主页&#x1f3c4;&#x1f…

Ubuntu 安装 CUDA 与 OPENCL

前言&#xff1a;最近需要做一些GPU并行计算&#xff0c;因而入坑CUDA和OPENCL&#xff0c;两者都有用到一些&#xff0c;刚好有点时间&#xff0c;同时记录一些学习过程&#xff0c;排掉一些坑&#xff0c;这篇是环境安装篇&#xff0c;基本跟着走就没什么问题&#xff0c;环境…

Qt5开发及实例V2.0-第二十一章-Qt.Quick Controls开发基础

Qt5开发及实例V2.0-第二十一章-Qt.Quick Controls开发基础 第21章 Qt Quick Controls开发基础21.1 Qt Quick Controls概述21.1.1 第一个Qt Quick Controls程序21.1.2 Qt Quick窗体应用程序的构成 21.2 Qt Quick控件21.2.1 概述21.2.2 基本控件21.2.3 高级控件21.2.4 样式定制 2…

基于MUSIC算法的二维超声波成像matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 4.1、基本原理 4.2、数学公式 4.3、实现过程 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 matlab2022a 3.部分核心程序 ..........................................…

比特币的蒙提霍尔问题

把钱放在嘴边 我们在比特币上建立了蒙提霍尔问题模拟。 如果您知道概率谜题的正确答案&#xff0c;不仅炫耀您的数学技能&#xff0c;还会获得金钱奖励。 它完全无需信任地在链上运行。 蒙提霍尔问题 蒙提霍尔问题&#xff08;三门问题&#xff09;是一个以蒙提霍尔命名的概率…

力扣-234.回文链表

Idea 用一个数组或者字符串将链表中的值依次存入&#xff0c;然后利用数组遍历方法比较双端元素 AC Code class Solution { public:bool isPalindrome(ListNode* head) {string s "";ListNode* p head;while(p ! nullptr){s.append(to_string(p->val));p p-&g…

SQL 如何提取多级分类目录

前言 POI数据处理&#xff0c;原始数据为csv格式&#xff0c;整理入库至PostGreSQL&#xff0c;本例使用PostGreSQL13版本。 一、POI POI&#xff08;一般作为Point of Interest的缩写&#xff0c;也有Point of Information的说法&#xff09;&#xff0c;通常称作兴趣点&am…

程序运行时增加语音提示

目录 前言 一、认识SAPI 二、使用方法 三、测试效果​编辑 总结 前言 在测试过程中为了更高效的提示操作者&#xff0c;在程序执行时增加语音提醒会方便很多&#xff0c;利用微软的SAPI可以很方便的在程序有问题时提示操作者。 一、认识SAPI SpVoice类是支持语音合成(TTS)的核…

ARP协议-介于数据链路层和网络层之间的协议

通过上一篇 IP协议 我们知道 目标IP目标网络 目标主机 &#x1f64b;‍ 也就是说 必须知道 接收方的接收方的 MAC地址 > 没有MAC地址无法封装 MAC帧 在网络层&#xff0c;我们可以知道目标主机的 IP 地址&#xff0c; 但是 我们不知道对方的MAC地址 。 在同一个网段&…

Tessy 5.0.4

Tessy 5.0.4 Linux 2692407267qq.com&#xff0c;更多内容请见http://user.qzone.qq.com/2692407267/