【JavaScript】LeetCode:16-20

news/2024/9/16 14:28:48/ 标签: javascript, leetcode, 开发语言

文章目录

  • 16 无重复字符的最长字串
  • 17 找到字符串中所有字母异位词
  • 18 和为K的子数组
  • 19 滑动窗口最大值
  • 20 最小覆盖字串

16 无重复字符的最长字串

在这里插入图片描述

  • 滑动窗口 + 哈希表
  • 这里用哈希集合Set()实现。
  • 左指针i,右指针j,从头遍历数组,若j指针指向的元素不在set中,则加入该元素,否则更新结果res,删除集合中i指针指向的元素,进入下一轮循环。
javascript">/*** @param {string} s* @return {number}*/
var lengthOfLongestSubstring = function(s) {var sset = new Set();var res = 0;var j = 0;for(var i = 0; i < s.length; i++){while(!sset.has(s[j]) && j < s.length){sset.add(s[j]);j++;}res = Math.max(res, j - i);sset.delete(s[i]);}return res;
};

17 找到字符串中所有字母异位词

在这里插入图片描述

  • 滑动窗口 + 哈希表
  • 创建哈希表p_map,记录字符串p中的字符;创建哈希表s_map,记录当前窗口中的字符。
  • 窗口左端点:left,窗口右端点:right;结果数组res。
  • 移动right指针,直到当前窗口的长度 = t的长度。当某个字符在s_map中的数量 = 该字符在p_map中需要的数量时,need++,即已经有一个字符满足了要求。
  • 当need = p_map.size时,所有字符的数量均满足了要求,此时更新结果:将left放入res中;然后移动left指针,缩小窗口,直到窗口中不包含字符串t中的所有字符,即有一个字符的数量不满足要求,就进入下一轮循环,再次移动right指针。
javascript">/*** @param {string} s* @param {string} p* @return {number[]}*/
var findAnagrams = function(s, p) {var p_map = new Map();var s_map = new Map();for(var item of p){p_map.set(item, (p_map.get(item) || 0) + 1);}var plen = p.length;var slen = s.length;var res = [];var left = 0;var need = 0;for(var right = 0; right < slen; right++){var a = s[right];if(p_map.get(a)){s_map.set(a, (s_map.get(a) || 0) + 1);if(s_map.get(a) == p_map.get(a)){need++;}}if(right - left == plen - 1){if(need == p_map.size){res.push(left);}var b = s[left];left++;if(p_map.get(b)){if(s_map.get(b) == p_map.get(b)){need--;}s_map.set(b, s_map.get(b) - 1);}}}return res;
};

18 和为K的子数组

在这里插入图片描述

  • 前缀和 + 哈希表
  • sums[i]:以nums[i]为结尾的前缀和。sums[j] - sums[i] = k,sums[j] - k = sums[i]。
  • sums[0] = 0,也要将“0:1”放入哈希表。
  • 遍历前缀和数组,先查找在哈希表中sums[item] - k的个数,然后再将当前元素放入哈希表中,注意:二者顺序不可调换,否则在k = 0时就会出错,例如[3],k = 0,若先放入“3:1”,则3 - k = 3 - 0 = 3,此时3的个数为1,结果记录就会 + 1,但其实是错误的。
javascript">/*** @param {number[]} nums* @param {number} k* @return {number}*/
var subarraySum = function(nums, k) {var sums = new Array(nums.length + 1).fill(0);for(var i = 0; i < nums.length; i++){sums[i + 1] = sums[i] + nums[i];}var map = new Map();var res = 0;for(var item of sums){res += map.get(item - k) || 0;map.set(item, (map.get(item) || 0) + 1);}return res;
};

19 滑动窗口最大值

在这里插入图片描述

  • 单调队列
  • 维护一个从出口到入口单调递减的队列,即出口处是最大值。这里的队列q记录索引值。
  • push()、pop():如果push的元素value大于队列中最后一个元素的数值,那么就将队列最后一个元素弹出,直到push元素的数值小于等于队列最后一个元素的数值为止。
  • 从i = k - 1开始记录,max = q[0]所对应的数值。
  • i与q[0]所指向的索引相差k时,弹出q[0]。
javascript">/*** @param {number[]} nums* @param {number} k* @return {number[]}*/
var maxSlidingWindow = function(nums, k) {var q = [];var res = [];for(var i = 0; i < nums.length; i++){while(q.length != 0 && nums[i] >= nums[q[q.length - 1]]){q.pop();}q.push(i);if(i - q[0] == k){q.shift();}if(i >= k - 1){res.push(nums[q[0]]);}}return res;
};

20 最小覆盖字串

在这里插入图片描述

  • 滑动窗口 + 哈希表
  • 创建哈希表t_map,记录字符串t中的字符;创建哈希表s_map,记录当前窗口中的字符。
  • 窗口左端点:left,窗口右端点:right;当满足条件时的字符串左端点:start,字符串长度:res。
  • 移动right指针,直到当前窗口中包含字符串t中的所有字符。当某个字符在s_map中的数量 = 该字符在t_map中需要的数量时,need++,即已经有一个字符满足了要求。
  • 当need = t_map.size时,所有字符的数量均满足了要求,此时更新结果:左端点start和字符串长度res;然后移动left指针,缩小窗口,直到窗口中不包含字符串t中的所有字符,即有一个字符的数量不满足要求,就进入下一轮循环,再次移动right指针。
javascript">/*** @param {string} s* @param {string} t* @return {string}*/
var minWindow = function(s, t) {if(s.length < t.length){return "";}var s_map = new Map();var t_map = new Map();for(var item of t){t_map.set(item, (t_map.get(item) || 0) + 1);}var need = 0;var left = 0;var start = 0;var res = Number.MAX_VALUE;for(var right = 0; right < s.length; right++){var a = s[right];if(t_map.has(a)){s_map.set(a, (s_map.get(a) || 0) + 1);if(s_map.get(a) == t_map.get(a)){need++;}}while(need == t_map.size){var b = s[left];if(right - left + 1 < res){start = left;res = right - left + 1;}left++;if(t_map.has(b)){if(s_map.get(b) == t_map.get(b)){need--;}s_map.set(b, s_map.get(b) - 1);}}}return (res == Number.MAX_VALUE)? "": s.slice(start, start + res);
};

http://www.ppmy.cn/news/1522632.html

相关文章

浙大数据结构:02-线性结构4 Pop Sequence

这道题我们采用数组来模拟堆栈和队列。 简单说一下大致思路&#xff0c;我们用栈来存1234.....&#xff0c;队列来存输入的一组数据&#xff0c;栈与队列进行匹配&#xff0c;相同就pop 机翻 1、条件准备 stk是栈&#xff0c;que是队列。 tt指向的是栈中下标&#xff0c;fr…

DPDK基础入门(五):报文转发

网络处理模块划分 Packet Input: 接收数据包&#xff0c;将其引入处理流程。Pre-processing: 对数据包进行初步处理&#xff0c;例如基本的检查和标记。Input Classification: 细化数据包的分类&#xff0c;例如基于协议或流进行分流。Ingress Queuing: 将数据包放入队列中进行…

Dubbo 安全方面措施

在分布式系统中&#xff0c;安全性是一个至关重要的因素&#xff0c;特别是对于像 Dubbo 这样的高性能 RPC 框架&#xff0c;确保服务的安全性和数据传输的完整性至关重要。Dubbo 作为一个成熟的分布式服务框架&#xff0c;在安全性方面提供了多种措施和配置选项&#xff0c;帮…

uniapp 给画作生成画框

<template><ax-page class"privateCustom"><gui-page :customHeader"true" ref"guipage"><template #gHeader><aHeader title"个性定制" :showTitle"true" back"2"></aHeader&g…

深度学习与大模型第4课:使用多种模型在Pima印度糖尿病数据集上的分类效果评估

文章目录 技术博客&#xff1a;使用多种模型在Pima印度糖尿病数据集上的分类效果评估数据集介绍数据预处理模型一&#xff1a;逻辑斯谛回归&#xff08;Logistic Regression&#xff09;模型二&#xff1a;支持向量机&#xff08;SVM&#xff09;模型三&#xff1a;决策树&…

1、正则表达式

1、正则表达式是一种用于描述文本模式的工具。它是由字符和特殊符号组成的字符串&#xff0c;描述了模式的重复或者多个字符&#xff0c;于是就可以按照某种模式匹配一系列有相似特征的字符串。它主要的作用是将文本用某种可被计算机识别的模式表现出来&#xff0c;为高级的文本…

Helm Deploy Online Rancher v2.9.1

文章目录 准备安装查看下载 准备 $ kubectl get node NAME STATUS ROLES AGE VERSION kube-master01 Ready control-plane 19d v1.29.5 kube-node01 Ready <none> 19d v1.29.5 kube-node02 Ready <none&…

Tekton简介,安装和构建最简单ci/cd

简介 Tekton是一种基于k8的支持CI/CD的operator。 说到持续集成&#xff0c;我们比较熟悉的有jenkins&#xff0c;gitlab ci等&#xff0c;但只有Tekton是云原生的。 既然Tekton是一种operator&#xff0c;那就必须了解它的CRD&#xff0c;然后我们定义CR&#xff0c;让Tekt…

WebAPI (一)DOM树、DOM对象,操作元素样式(style className,classList)。表单元素属性。自定义属性。间歇函数定时器

文章目录 Web API基本认知一、 变量声明二、 DOM1. DOM 树2. DOM对象3. 获取DOM对象(1)、选择匹配的第一个元素(2)、选择匹配多个元素 三、 操作元素1. 操作元素内容2. 操作元素属性(1)、常用属性&#xff08;href之类的&#xff09;(2)、通过style属性操作CSS(3)、通过类名(cl…

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、…

golang hertz框架入门

两种模式新建项目 1、手动新建项目 2、使用hz工具新建项目 一、手动创建项目&#xff0c;并拉取框架 1、新建项目目录 hertz_demo_w 2、在项目跟目录新建main.go 文件 package mainimport ("context""github.com/cloudwego/hertz/pkg/app""github.…

API安全 | 发现API的5个小tips

在安全测试目标时&#xff0c;最有趣的测试部分是它的 API。API 是动态的&#xff0c;它们比应用程序的其他部分更新得更频繁&#xff0c;并且负责许多后端繁重的工作。在现代应用程序中&#xff0c;我们通常会看到 REST API&#xff0c;但也会看到其他形式&#xff0c;例如 Gr…

C# 使用国密SM4加密解密

首先需第三方Nuget包&#xff1a;Portable.BouncyCastle &#xff08;源码来自http://www.bouncycastle.org/csharp/&#xff09;&#xff0c;支持.NET 4,.NET Standard 2.0 目录 使用BouncyCastle指定填充方案 零填充&#xff08;Zero Padding&#xff09; PKCS7填充&…

MariaDB基本知识汇总

/* MariaDB 1、视图 2、临时表 3、自定义函数 4、存储过程 5、触发器 6、游标 7、变量声明与赋值 8、常用函数&#xff08;日期格式&#xff0c;Guid&#xff0c;判断&#xff0c;循环&#xff0c;XML格式操作&#xff09; 9、动态执行SQL 语句 10、开启执行计划 11、创建登录M…

AI智能分析/智慧安防EasyCVR视频汇聚平台新版本(V3.6.0)播放鉴权与播放限制时长的区别介绍

随着科技的飞速发展&#xff0c;视频技术已成为现代社会不可或缺的一部分&#xff0c;广泛应用于安防监控、娱乐传播、在线教育、电商直播等多个领域。EasyCVR视频汇聚平台作为视频技术的佼佼者&#xff0c;不断推陈出新&#xff0c;通过功能更新迭代&#xff0c;为用户提供更加…

什么是视频缓存服务器,它有哪些作用?

视频缓存服务器通常拥有大容量的存储空间和高速的读写能力&#xff0c;它通过缓存(即临时存储)用户经常访问的视频内容&#xff0c;来优化内容的分发过程。这种服务器通常部署在网络中的关键位置&#xff0c;如靠近用户接入点的位置&#xff0c;以降低用户访问视频内容时的网络…

rtsp服务器逻辑

定时器逻辑&#xff1a;比如H264文件是每隔40ms发送一帧数据。aac文件每隔23ms发送一个音频帧数据。 在sink的子类中有aac和h264的sink&#xff0c;在两个子类的构造函数中需要添加它们各自的触发时间。调用的函数时runEvery()&#xff0c;将这两个触发时间设置到了TimerManag…

【H2O2|全栈】关于HTML(1)认识HTML

HTML相关知识 目录 前言 准备工作 WEB前端是什么&#xff1f; HTML是什么&#xff1f; 如何运行HTML文件&#xff1f; 标签 概念 分类 双标签和单标签 行内标签和块标签 HTML文档结构 预告和回顾 UI设计相关 Markdown | Md文档相关 项目合作管理相关 后话 前…

数据结构之堆的创建

1、堆的概念及结构 1.1堆的概念 如果有一个关键码的集合K{k0,k1,k2,…,kn-1}&#xff0c;把它的所有元素按完全二叉树的顺序存储方式存储在一个一维数组中&#xff0c;并满足ki<k2i1且ki<k2i2&#xff08;或满足ki>k2i1且ki>k2i2&#xff09;&#xff0c;其中i0…

Vue2项目搭建:Vue2.7+Vite4+Pinia+TailwindCSS+Prettier+ESLint

目前 create-vue 和 Vite 都不提供 Vue2 项目的搭建&#xff0c;不想用 Vue CLI 和 webpack&#xff0c;于是就打算从 0 搭建一个工程化项目&#xff0c;支持组合式 API (Composition API) 写法&#xff0c;没有使用 TypeScript&#xff0c;有朋友需要的话我可以再完善一下。 N…