算法/编程练习:寻找和至少为K的最短子数组

2024-09-04 18:32

本文主要是介绍算法/编程练习:寻找和至少为K的最短子数组,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

寻找和至少为K的最短子数组


1. 题目

题目来自LeetCode:
https://leetcode-cn.com/problems/shortest-subarray-with-sum-at-least-k/

题目:

返回非空列表A的最短的非空连续子数组的长度,该子数组的和至少为K。
如果没有和至少为K的非空子数组,返回 -1 。
例如,
input: A = [1, 2],  K = 4
output:  -1input: A = [2, -1, 2],  K = 3
output:  3

2. 思路(来自官方题解):

题目转换:
记P存放A的累计求和列表(P[x+1] = P[x] + A[x])
找到在满足P[y]-P[x] >= K情况下使y-x最小的y-x解答思路:全局最优解:最终需要的结果特定最优解x:当y固定时,满足条件的最大x特定最优解x满足规律:当y固定的时候,若x2 > x1且P[x2] <= P[x1](相当于A[x1]和A[x2]之间有负数)则x1必然不是y对应的特定最优解,因为若x1可行,则x2也可行且比x1更优因此(在x递增的方向)寻找y的特定最优解时,若x1 < x2且P[x1] >= P[x2],则x1可直接删除当x为多个y的特定最优解时的规律:对于任何y2 > y1,若x同时是y1和y2对应的特定最优解,则y1-x一定优于y2-x因此在y递增的方向寻找全局最优解时,若x是y的特定最优解,则后续不用再考虑x(因为y递增)用一个双端列队deq存放可能是特定最优解的下标x,然后求解分两个步骤,对A的每个元素A[y]:1) 首先y固定,删除deq中所有x < y且P[x] > P[y]的x2) 对deq中的从小到大的每个下标x,若x为y的特定最优解,则将其删除

3. Python代码:

# -*- coding: utf-8 -*-import collectionsdef SumKShortestSublist(A, K):if not isinstance(A, list) or len(A) < 1:print('A须为非空列表!')return -1N = len(A)P = [0] # 存放累计和列表for a in A:P.append(P[-1] + a)best_ans = N+1 # best_ans记录全局最优解,N+1 is impossible    deq = collections.deque() # 双端列队deq存放可能是特定最优解的下标xfor y, P_y in enumerate(P):# 当y固定时,删除d中所有x < y且P[x] > P[y]的xwhile deq and P_y <= P[deq[-1]]:deq.pop()# 若x是y的特定最优解,则后续不用再考虑xwhile deq and P_y - P[deq[0]] >= K:best_ans = min(best_ans, y-deq.popleft())deq.append(y)return best_ans if best_ans < N+1 else -1if __name__ == '__main__':A = [1]K = 1print(SumKShortestSublist(A, K))A = [1, 2]K = 5print(SumKShortestSublist(A, K))    A = [2, 1, 2]K = 3print(SumKShortestSublist(A, K))A = [2, -1, 2]K = 3print(SumKShortestSublist(A, K))A = [84, -37, 32, 40, 95]K = 167print(SumKShortestSublist(A, K))

欢迎关注公众号:一本正经d胡说
Genlovy562

这篇关于算法/编程练习:寻找和至少为K的最短子数组的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1136699

相关文章

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

JAVA数组中五种常见排序方法整理汇总

《JAVA数组中五种常见排序方法整理汇总》本文给大家分享五种常用的Java数组排序方法整理,每种方法结合示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录前言:法一:Arrays.sort()法二:冒泡排序法三:选择排序法四:反转排序法五:直接插入排序前言:几种常用的Java数组排序

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Python 异步编程 asyncio简介及基本用法

《Python异步编程asyncio简介及基本用法》asyncio是Python的一个库,用于编写并发代码,使用协程、任务和Futures来处理I/O密集型和高延迟操作,本文给大家介绍Python... 目录1、asyncio是什么IO密集型任务特征2、怎么用1、基本用法2、关键字 async1、async

Springboot实现推荐系统的协同过滤算法

《Springboot实现推荐系统的协同过滤算法》协同过滤算法是一种在推荐系统中广泛使用的算法,用于预测用户对物品(如商品、电影、音乐等)的偏好,从而实现个性化推荐,下面给大家介绍Springboot... 目录前言基本原理 算法分类 计算方法应用场景 代码实现 前言协同过滤算法(Collaborativ

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Java数组初始化的五种方式

《Java数组初始化的五种方式》数组是Java中最基础且常用的数据结构之一,其初始化方式多样且各具特点,本文详细讲解Java数组初始化的五种方式,分析其适用场景、优劣势对比及注意事项,帮助避免常见陷阱... 目录1. 静态初始化:简洁但固定代码示例核心特点适用场景注意事项2. 动态初始化:灵活但需手动管理代

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各