leetcode 560 和为k 的子数组

news2024/9/21 22:39:29

leetcode 560 和为k 的子数组

  • 正文
  • 一般解法
  • 字典方法

正文

在这里插入图片描述

一般解法

class Solution:
    def subarraySum(self, nums: List[int], k: int) -> int:
        number = 0
        for i in range(len(nums)):
            for j in range(i , len(nums)):
                if sum(nums[i:j + 1]) == k:
                    number += 1

        return number

上述方法虽然可行,但是时间复杂度为 O ( n 2 ) O\left(n^2\right) O(n2)。不够迅速,因此,我们考虑使用其他方式实现。

字典方法

import collections
from typing import List


class Solution:
    def subarraySum(self, nums: List[int], k: int) -> int:
        count = 0
        dict1 = collections.defaultdict(int)
        dict1[0] = 1

        pre_sum = 0

        for i in range(len(nums)):
            pre_sum += nums[i]
            count += dict1[pre_sum - k]
            dict1[pre_sum] += 1

        return count

需要特别注意的是,这里的 count += dict1[pre_sum - k]dict1[pre_sum] += 1 位置不能互换。

如果大家觉得有用,就请点个赞吧~

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

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

相关文章

北斗卫星导航系统的应用落地,改变未来出行方式

近年来,随着北斗卫星导航系统在全球范围内的部署和完善,它的应用范围不断扩大,正逐渐成为数字化出行时代的重要基础设施。从智能导航到车联网,从航空导航到陆地测绘,北斗卫星导航系统的应用正在深入各个领域&#xff0…

视频单条剪、脚本靠手写?云微客开启海量视频时代

老板们注意了,现在已不再是视频单条剪,脚本靠手写的时代!在这个信息爆炸的时代,短视频已经成为了现代信息传播和娱乐消费的重要载体,那么我们该如何高效、快速地制作出大量高质量的短视频内容呢?这就需要云…

TRIZ理论在手术机器人功能区设计中的应用

TRIZ,全称为“Theory of Inventive Problem Solving”,是一套系统化地分析和解决复杂问题的理论工具。它不仅能够预测技术系统的发展趋势,还能提供一套高效的问题解决策略,帮助设计师突破思维定势,实现突破性创新。在手…

视频转换成MP3怎么转?这里有快速转换通道

视频转换成MP3怎么转?在数字化时代,视频和音频内容无处不在,我们时常需要将视频中的音频提取出来,以便在特定场合下单独播放或编辑。将视频转换成MP3音频格式是一种常见且实用的需求。为了帮助你轻松实现这一操作,本文…

openlayers10+vue3+ts

在 Vue 3 应用程序中使用 Vite 工具链和 OpenLayers10 创建一个简单的地图实例,并实现一些基础的地图交互功能。 Demo 地图初始化 底图加载与切换 GeoJSON 数据的加载与导出 绘制功能 轨迹回放功能 使用 VectorLayer postrender 实现丝滑的轨迹运动效果。

基于Java的音乐网站与分享平台

你好,我是音乐技术爱好者,专注于音乐与技术的结合。如需交流或合作,请联系我。 开发语言:Java 数据库:MySQL 技术:Java语言,Spring Boot框架,B/S架构 工具:Eclipse&a…

007、架构_MDS

​架构 什么是元数据 什么是元数据 元数据又称中介数据、中继数据,为描述数据的数据,主要是描述数据属性的信息,用来支持如指示存储位置、历史数据、资源查找、文件记录等功能;GoldenDB 数据库元数据大致分为两类: 数据字典:库、表、字段属性信息、视图、函数、存储过程属…

【数据结构-前缀异或】力扣1310. 子数组异或查询

有一个正整数数组 arr,现给你一个对应的查询数组 queries,其中 queries[i] [Li, Ri]。 对于每个查询 i,请你计算从 Li 到 Ri 的 XOR 值(即 arr[Li] xor arr[Li1] xor … xor arr[Ri])作为本次查询的结果。 并返回一…

SpringBoot2:依赖管理与自动配置

一、依赖管理 什么叫依赖管理? 我们做过Maven项目的,都知道pom.xml的作用。里面配置了一大堆的包依赖。 所以,SpringBoot的依赖管理,意思就是,我们用SpringBoot开发web应用,那么,相关的依赖包&…

添加专辑失败,获取 userId 为空

文章目录 1、debug发现问题2、发现 userId 为空3、GuiGuAspect4、GuiGuLogin 1、debug发现问题 2、发现 userId 为空 点击 getUserId() 进入方法内部 package com.atguigu.tingshu.common.util;/*** 获取当前用户信息帮助类*/ public class AuthContextHolder {private stati…

【Python】copy()浅拷贝与深拷贝

前言 由于python关于传参的方面和C语言有些出入,对于先学C在学Python的可能需要做些笔记,比如Python中def传参是直接传址,而不是传值创建局部变量等等...而到了copy函数感觉又是个新概念... 1. copy介绍 1.1 copy() 浅拷贝 Python 的 cop…

如何解决 Compute 节点上的内存溢出(OOM)问题

内存溢出(Out-of-memory)是数据处理系统中常见的问题,本文将分析 OOM 的各种原因并提供有效的解决方法。 RisingWave 使用像 AWS S3 这样的共享存储,并将 Compute 节点的内存用作缓存以增强流处理性能。缓存以 Least Recently Us…

最新盘点!推荐10款简单易用的进销存软件!

本文将会盘点10款比较简单的进销存软件: 简道云、秦丝生意通、管家婆、金蝶精斗云、用友 T、百胜软件、速达软件、商陆花、Zoho Inventory、QuickBooks。 进销存软件就如同企业的得力助手。它能把企业的进货、销售和库存管理得妥妥当当,让企业清楚地掌握…

微深节能 堆取料机回转俯仰角度检测系统 格雷母线定位系统

微深节能在堆取料机回转俯仰角度检测系统中引入的格雷母线定位系统,是一项重要的技术创新,显著提升了堆取料作业的自动化水平和精确性。以下是对该系统的详细介绍: 一、系统概述 格雷母线定位系统作为高精度、无磨损的非接触式位置检测系统&a…

uni-app - - - - - 自定义状态栏

uni-app - - - - - 自定义状态栏 1. 效果图 2. pages.json配置 在需要使用自定义状态栏的页面,添加如下配置 {"path": "pages/index/index","style": {"navigationBarTitleText": "",// 使用自定义状态栏"…

apache httpclient速成

目录标题 快速使用连接池参数连接池状态清除闲置连接evictIdleConnections删除过期连接 timeToLive 和evictExpiredConnections 注意释放内存关闭流 http和netty的关系 导入依赖 <dependency><groupId>org.apache.httpcomponents.client5</groupId><artif…

STM32 - 笔记3

1 开发有基于寄存器和HAL库 在开发 STM32 系列微控制器时&#xff0c;你可以选择基于寄存器的开发方法或使用 STM32 HAL&#xff08;硬件抽象层&#xff09;库进行开发。两者各有优缺点&#xff0c;适用于不同的场景和开发需求。下面详细介绍两种方法的特点、使用场景以及示例…

头条/微头条文章采集洗稿发布软件(文字版)说明文档/使用教程

大家好&#xff0c;我是淘小白~ 今天给【头条/微头条文章采集洗稿发布软件】做一个文字版的使用说明文档&#xff01; 旧版说明文档&#xff08;含视频&#xff09;&#xff1a;https://blog.csdn.net/u012917925/article/details/141280090 注意&#xff1a;软件版本一直在…

JS实现不同网页间的数字员工与数据存储

一、目标任务&#xff1a; 要去 https://sjfw.scjs.net.cn:8801/xxgx/Enterprise/eList.aspx 根据企业名称查询到统一社会征信代码。 然后拿统一社会征信代码去 https://rzsc.sczwfw.gov.cn/portal/newOrg/orgRegister.jsp 查询法人信息。 最后两个页面不断跳转进行信息存储…

pythonnet-C#调用python脚本-含matplotlib+biopython

本地环境&#xff1a; win10&#xff0c;.NET Core 6&#xff0c;Python 3.9.13&#xff0c;pythonnet 3.0.3 测试的包&#xff1a;biopython 1.82&#xff0c;matplotlib 3.5.2 参考&#xff1a; GitHub - pythonnet/pythonnet: Python for .NET is a package that gives Py…