力扣100题——子串

news2025/1/16 17:48:22

560.和为k的子数组

这道题目不是滑动窗口的类型,因为长度并不是固定的。(好的,我在说废话)

注意题目要求是子数组,且是连贯的。那这里的话,解法有很多,最简单的就是暴力解法,但在这里我想说的是前缀和加哈希表优化,嘿嘿,适当的参考了一下官方的解题办法。ok,来。

首先什么是前缀和,先看个列子:

有个数组:nums=[1,2,3,4,5,6],那么他的前缀和就是0,1,3,6,10,15,21。

当i=0的时候,前缀和是0,

当i=1的时候,前缀和是1,

当i=2的时候,前缀和是0+1+2=3,以此类推。

我们已经知道了前缀和的值和k的值,那想求的是题目要求的连续子数组和为k的数,那是不是只要把当前的前缀和-k就可以得到连续的子数组的和,我们之前是用一个数组来表示的,那如果说得到的那个值出现在了这个数组中,是不是就说明找到了,上代码:

class Solution {
    public int subarraySum(int[] nums, int k) {
       int count=0,pre=0;
       //定义一个map,来存放各个前缀和出现的次数
       HashMap<Integer,Integer> mp=new HashMap<>();
       //这个主要是用以考虑连续数组只有一个的情况,比如说例子2中的3
       mp.put(0,1);
       for(int i=0;i<nums.length;i++){
           pre+=nums[i];
           if(mp.containsKey(pre-k)){
               count+=mp.get(pre-k);
           }
           mp.put(pre,mp.getOrDefault(pre,0)+1);
       }
       return count;
    }
}

239、滑动窗口最大值

题解:这道题用了一个优先队列。在优先队列里面的元素是已经排列好的。要注意的是用C++和Python是不一样的。前者是默认从高到低对数组进行排列,而后者是从低到高,所以用python的时候需要注意要对其取负值。

解题思路:用优先队列,定义一个优先队列,然后将前面的k值放入队列中,将最大的那个元素存入数组中,接着利用for循环,从k值开始,将新元素放入队中,同时判断当前窗口中最大值是否在i-k中,如果不是则需要弹出

纠结点

1.就是用while循环弹出的是一系列吗?,存在的意义是什么。

while循环的目的在于弹出窗口中最大的元素,但要注意前提条件。如果此时窗口滑到了[-1,-1,-2],那前面所有大于这个窗口里面的最大值都要出队pop掉,看个例子吧,我放个代码,看看就懂了。

import heapq
class Solution:
    def maxSlidingWindow(nums, k):
        n = len(nums)
        # 注意 Python 默认的优先队列是小根堆
        q = [(-nums[i], i) for i in range(k)]
        #这里的作用是将其调整成为一个大根堆,q本身就发生了改变,并返回none
        heapq.heapify(q)
        ans = [-q[0][0]]
        for i in range(k, n):
            heapq.heappush(q, (-nums[i], i))
            while q[0][1] <= i - k:
                # print("当前的k,i:",k,i)
                print("弹出的q值为:",q[0][0])
                #将q对列中弹出最小的元素
                heapq.heappop(q)
                # print("弹出之后的q值",q)
            ans.append(-q[0][0])
            print("q2的值为", q)
        return ans
nums=[1,0,-1,-3,5,3,6,7,9,10,-1,-1,-2,-3,3,2,3,1]
nums1=[1]
k=3
m=Solution.maxSlidingWindow(nums,k)
print(m)

2.python代码的误解

heapq.heappop(q),这串代码的意思是弹出q中最小的元素,所以print(q)是输出q这个队列里面的所有元素,而不只是队列中最大的元素

3、当窗口右移时,只需要判断最大值是否在滑动窗口中。所以说如果此时通过右移添加的元素是大于之前窗口中的最大值的,这种情况下此时while循环里面它的最大值就是当前元素,比较的下标也是当前元素的。所以就不要纠结为什么之前窗口最大的无法弹出了,因为它遇见了一个比它更大的,懂了吧。

下面的代码是我在pycharm编译器里面测试编写的,若要放在力扣上面的话记得改动一下。

代码:

import heapq
class Solution:
    def maxSlidingWindow(nums, k):
        n = len(nums)
        # 注意 Python 默认的优先队列是小根堆
        q = [(-nums[i], i) for i in range(k)]
        #这里的作用是将其调整成为一个大根堆,q本身就发生了改变,并返回none
        heapq.heapify(q)
        ans = [-q[0][0]]
        for i in range(k, n):
            heapq.heappush(q, (-nums[i], i))
            while q[0][1] <= i - k:
                print("此时的i,k,q[0][1]分别为",i,k,q[0][1])
                print("弹出的q值为:",q[0][0])
                #将q对列中弹出最小的元素
                heapq.heappop(q)
                print("弹出之后的q值",q)
            ans.append(-q[0][0])
            print("q2的值为", q)
        return ans
nums=[1,0,-1,-3,5,3,6,7]
nums1=[1]
k=3
m=Solution.maxSlidingWindow(nums,k)
print(m)

76.最小覆盖子串

思路

这道题目的意思是要寻找s中覆盖t的连续最短子串,那我们可以用一个字典need来存储各个元素出现的次数,以及用needCnt来标识此时滑动窗口中的元素是否全部包括t中的元素,再用元组res来存储各个满足条件的窗口中的长度的下标。用i和j分别代表窗口的左边界和右边界,然后右移窗口,直到needCnt==0停止,这就代表着窗口中的元素已经全部包括t了,这里需要判断此时的元素出现的次数是否大于0,是的话长度得减1,减一和加一的标准是j++时,--,i++时,++。具体的大家看代码应该就能看懂了。加油!!!

代码:

class Solution:
    def minWindow(self, s: str, t: str) -> str:
        # 1.创建一个字典,用以存储各个字母出现的次数
        need=collections.defaultdict(int)
        # 循环遍历t数组,统计次数存入need中
        for c in t:
            need[c]+=1
        # 更新needCnt的值,此时就是t数组的长度,当其能匹配到S中相应的字符时,便减一直到为0
        needCnt=len(t)
        # 代表左边窗口
        i=0
        # 定义元组的大小,右边表示正无穷
        res=(0,float('inf'))
        # 循环遍历s数组
        for j,c in enumerate(s):
            #当s中的字符对应在字典中的值大于0时,needCnt--,因为只要是在右移的过程中,碰到的元素都是--的
            if need[c]>0:
                needCnt-=1
            need[c]-=1
            #当窗口中的元素的所有值都包含了t中的元素值之后,便开始移动左边窗口了
            if needCnt==0:
                while True:
                    c=s[i]
                    # 直到移动的元素是t中的,即need[c]==0,这里不考虑其他元素有没有可能为0的情况,因为如果为0,那就已经不在滑动窗口中了,目标元素在原始情况下是+1的,从此便区分开了
                    if need[c]==0:
                        break
                    need[c]+=1
                    i+=1
                #直到遇到t中元素的边界,这里就需要存储一下窗口大小,便于后续取出,之后便再次移动左边界,寻找遍历最短的包括t数组的连续数组
                if j-i<res[1]-res[0]:
                    res=(i,j)
                need[s[i]]+=1
                needCnt+=1
                i+=1
        # 这里切片
        return '' if res[1]>len(s) else s[res[0]:res[1]+1]

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

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

相关文章

ChatGPT 如何改变科研之路

《Nature》全球博士后调查[1]中约有三分之一的受访者正在使用人工智能聊天机器人来帮助完善文本、生成或编辑代码、整理其领域的文献等等。 来自巴西的 Rafael Bretas 在日本生活了十多年&#xff0c;日语说得很好。书面日语的各个方面&#xff0c;例如严格的礼貌等级制度&…

CCNA课程实验-12-NAT

目录 实验条件网络拓朴需求 配置实现基础配置R1PC1ISPR2HTTP_ServerDNS_Server 配置在R2上配置静态NAT&#xff0c;将内网DNS Server关联到公网IP&#xff1a;202.1.1.2测试结果 配置在R2上配置静态NAT&#xff0c;将内网HTTP Server的TCP 80端口关联到公网IP&#xff1a;202.1…

力扣138:随机链表的复制

力扣138&#xff1a;随机链表的复制 题目描述&#xff1a; 给你一个长度为 n 的链表&#xff0c;每个节点包含一个额外增加的随机指针 random &#xff0c;该指针可以指向链表中的任何节点或空节点。 构造这个链表的 深拷贝。 深拷贝应该正好由 n 个 全新 节点组成&#xff…

TiPro7000 Smart Tool V1.1无法打开解决办法

长江存储官网下载的TiPro7000 Smart Tool V1.1在win10运行时无法打开&#xff0c;转圈圈之后就没有反应了。官网下载的压缩包解压之后内容如下图。 解决办法&#xff1a;将.exe文件名的“致钛”二字删掉即可。文件名不能有中文。 打开后软件界面如下。 吐槽一下这软件做得挺简…

【Python大数据笔记_day06_Hive】

hive内外表操作 建表语法 create [external] table [if not exists] 表名(字段名 字段类型 , 字段名 字段类型 , ... ) [partitioned by (分区字段名 分区字段类型)] # 分区表固定格式 [clustered by (分桶字段名) into 桶个数 buckets] # 分桶表固定格式 注意: 可以排序[so…

Java,多线程,线程安全的懒汉式、死锁、ReentrantLock的使用以及一些知识点补充

关于线程安全地懒汉式有以下几种方式&#xff1a; /*** 实现线程安全的懒汉式*/ public class BankTest {Bank b1 null;Bank b2 null;public static void main(String[] args){BankTest bb new BankTest();Thread t1 new Thread(){Overridepublic void run(){bb.b1 Bank.…

【C++笔记】优先级队列priority_queue的模拟实现

【C笔记】优先级队列priority_queue的模拟实现 一、优先级队列的介绍与使用方式1.1、优先级队列介绍1.2、优先级队列的常见使用 二、优先级队列的模拟实现1.0、仿函数的介绍1.1、构造函数1.2、优先级队列的插入push1.3、优先级队列的删除(删除堆顶元素)1.4、获取堆顶元素1.5、判…

【蓝桥每日一题]-快速幂,倍增,滑动窗口(保姆级教程 篇1) #麦森数 #青蛙跳

之前是考试准备&#xff0c;所以有几天没更新&#xff0c;今天开始继续更新 目录 快速幂模板 题目&#xff1a;麦森数 思路&#xff1a; 题目&#xff1a;青蛙跳 思路&#xff1a; 快速幂模板 #include <bits/stdc.h> #define ll long long using namespa…

人工智能与教育:未来的技术融合

人工智能与教育&#xff1a;未来的技术融合 随着科技的飞速发展&#xff0c;人工智能&#xff08;AI&#xff09;逐渐渗透到我们生活的方方面面&#xff0c;包括教育领域。AI与教育的结合&#xff0c;有望引发一场教育变革&#xff0c;提高教学效果&#xff0c;实现个性化学习&…

ENVI IDL:如何基于气象站点数据进行反距离权重插值?

01 前言 仅仅练习&#xff0c;大可使用ArcGIS或者已经封装好的python模块进行插值&#xff0c;此处仅仅从底层理解如何从公式和代码理解反距离权重插值的过程&#xff0c;从而更深刻的理解IDL的使用和插值的理解。 02 函数说明 2.1 Read_CSV()函数 官方语法如下&#xff1a…

JVM虚拟机:垃圾回收器之Parallel Old(老年代)

本文重点 本文将学习老年代的另外一种垃圾回收器Parallel Old(PO)&#xff0c;这是一种用于老年代的并行化垃圾回收器&#xff0c;它使用标记整理算法进行垃圾回收。 历史 在1.6之前&#xff0c;新生代使用Parallel Scavenge只能搭配老年代的Serial Old收集器&#xff0c;而…

蓝桥杯算法双周赛心得——被替换的身份证(分类讨论)

大家好&#xff0c;我是晴天学长&#xff0c;分类讨论一定要细节啊&#xff0c;需要的小伙伴可以关注支持一下哦&#xff01;后续会继续更新的。&#x1f4aa;&#x1f4aa;&#x1f4aa; 1) .被替换的身份证 2) .算法思路 假设一方获胜 1.接受数据 2.假设潜梦醒 无非就是&am…

Image透明度点击简述以及Unity2019之后存在无法点击的BUG修复

前言 自Unity2019之后Unity将UGUI模块从内置库修改成了通过PackageManger引入的方式。Image就来源于com.unity.modules.imgui模块。其实代码大体代码跟2018是一致的&#xff0c;但是还是有些细微差别&#xff0c;Image透明度点击不命中就是2019之后才有的问题&#xff0c;2018…

JVM虚拟机:垃圾回收器之CMS(老年代)

本文重点 在前面的课程中我们学习了Serial和PO垃圾回收器,本文将学习一种新的在老年代使用的垃圾回收器CMS。 特点 CMS收集器是一种以获取最短回收停顿时间为目标的收集器(还是会有短暂的STW),适合互联网或者B/S系统的服务器上,这类应用尤其重视服务器的响应速度,希望…

SQL必知会(二)-SQL查询篇(6)-创建计算字段

第7课、创建计算字段 1&#xff09;拼接字段 需求&#xff1a;检索Vendors 表包含供应商的名称和地址的所有信息&#xff0c;返回结果需要把地址括号起来。 SELECT vend_name ( vend_country ) FROM Vendors ORDER BY vend_name;-- 以下例子与上面例子相同工作 SELECT ve…

Rust的崛起:现代必备编程语言,是时候该考虑加入学习了

在不断变化的编程环境中&#xff0c;新的语言和框架如雨后春笋般涌现&#xff0c;需要一个真正强大且设计良好的工具才能脱颖而出。在这些工具中&#xff0c;Rust 已成为效率、安全性和性能的灯塔。从它作为 Mozilla 的一个副项目到它在软件行业中不可否认的增长&#xff0c;Ru…

PHP中传值与引用的区别

在PHP中&#xff0c;变量的传递方式主要分为传值和传引用两种。这两种方式在操作中有一些重要的区别&#xff0c;影响着变量在函数调用或赋值操作中的表现。下面详细解释一下这两种传递方式的区别。 传值&#xff08;By Value&#xff09; 传值是指将变量的值复制一份传递给函…

Python环境安装、Pycharm开发工具安装(IDE)

Python下载 Python官网 Python安装 Python安装成功 Pycharm集成开发工具下载&#xff08;IDE&#xff09; PC集成开发工具 Pycharm集成开发工具安装&#xff08;IDE&#xff09; 安装完成 添加环境变量&#xff08;前面勾选了Path不用配置&#xff09; &#xff08;1&…

个人技术支持

本人目前从事 cnc 自动编程相关职业&#xff0c;主要还是做上位机开发&#xff0c;2021年之前一直从事 Unity3d 开发&#xff0c;本来也是个游戏程序员&#xff0c;后面也是大环境不好&#xff0c;改做了上位机开发&#xff0c;没想到上位机行业现在也是这么不好找工作。 最近…

java 类和对象 (图文搭配,万字详解!!)

关于java类和对象&#xff0c;我们要掌握几个重点&#xff01; 1.类的定义方式以及对象的实例化 2.类中的成员变量和成员方法的使用 3.对象的整个初始化过程 4.封装特性 5.代码块 目录 一、面向对象的初步认识 1.1 什么是面向对象 1.2 面向对象与面向过程 1.2.1传统洗…