HDU Max Sum of Max-K-sub-sequence(单调队列)

2024-05-03 19:32

本文主要是介绍HDU Max Sum of Max-K-sub-sequence(单调队列),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

                                  Max Sum of Max-K-sub-sequence


题目链接:Click Here~

题目分析:

     题意要求给出N给数的序列,要求你求出其在满足连续子串长度不超过k的最大和。

思路分析:

     我们以前都做过,是同一个作者出的题,叫MAX Sum和Max Sum Plus其实这两道题的思想都是差不多的,只是到了MAX SUM PLUS PLUS 之后解题思路就要发生本质上的变化了。扯远了。说回这道题吧,显然很容易想到的算法是N*K的暴力遍历。但这个是明显超时的节奏。所以,要另寻他法。

    经过思考之后,我们可以很容易的想到运用前缀和思想。但是题目要求的是K个数,这就是本题的一个卡,我们要如何去突破呢?在经过思考我们有可以在进一步的发现前缀和的特点。例如,6 5 7 1 3 8如果,我们假定最后的结果是以8那个数结尾的,那么如何找到最大的k个连续和呢?显然,只要我们找到了前面最小的(8 - min),则结果一定会最大。但是这个前面的数不能和8的position超过K位.则这个数就是我们要求的答案了。

算法实现:

    既然知道了实现思路,那么我们要如何去快速的找到那个在当前值前面不超过K个数的最小值呢?

    经过思考,我们可以发现我们只要运用一个单调队列就可以达到这个要求了。

  

#include <iostream>
#include <algorithm>
#include <string>
#include <cstdio>
using namespace std;const int N = 1e5 + 10;
int sum[2*N],a[2*N],num[2*N];
int main()
{int T,n,k;scanf("%d",&T);while(T--){sum[0] = 0;scanf("%d%d",&n,&k);for(int i = 1;i <= n;++i){scanf("%d",&a[i]);sum[i] = sum[i-1] + a[i];a[i+n] = a[i];}for(int i = n+1;i <= n+k;++i)sum[i] = sum[i-1] + a[i];int rear = 0,front = 0;int st = 1,ed = 1,maxv = -1e10;for(int i = 1;i <= n+k;++i){while(front < rear&&sum[num[rear-1]] > sum[i-1]) rear--;    //保持队列的单调递增/* 当调用while时我们可以知道此时是出现了负数。我们知道当sum[num[rear-1]] > sum[i-1]成立时,此时队列中的元素(sum[num[rear-1]] > sum[i-1])必须出列。因为,后面的数减去sum[num[rear-1]]中的数,一定比减去sum[i-1]的值小。所以我们就让其出列,从而提高代码的效率。 */                       num[rear++] = i - 1;       while(front < rear&&i - num[front] > k) front++;           //使结果至多k个数if(sum[i] - sum[num[front]] > maxv){maxv = sum[i] - sum[num[front]];st = num[front]+1;ed = i;}}if(st > n) st -= n;if(ed > n) ed -= n;printf("%d %d %d\n",maxv,st,ed);}return 0;
}



这篇关于HDU Max Sum of Max-K-sub-sequence(单调队列)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java中常见队列举例详解(非线程安全)

《Java中常见队列举例详解(非线程安全)》队列用于模拟队列这种数据结构,队列通常是指先进先出的容器,:本文主要介绍Java中常见队列(非线程安全)的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一.队列定义 二.常见接口 三.常见实现类3.1 ArrayDeque3.1.1 实现原理3.1.2

C++ RabbitMq消息队列组件详解

《C++RabbitMq消息队列组件详解》:本文主要介绍C++RabbitMq消息队列组件的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. RabbitMq介绍2. 安装RabbitMQ3. 安装 RabbitMQ 的 C++客户端库4. A

golang实现延迟队列(delay queue)的两种实现

《golang实现延迟队列(delayqueue)的两种实现》本文主要介绍了golang实现延迟队列(delayqueue)的两种实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目录1 延迟队列:邮件提醒、订单自动取消2 实现2.1 simplChina编程e简单版:go自带的time

PyTorch中cdist和sum函数使用示例详解

《PyTorch中cdist和sum函数使用示例详解》torch.cdist是PyTorch中用于计算**两个张量之间的成对距离(pairwisedistance)**的函数,常用于点云处理、图神经网... 目录基本语法输出示例1. 简单的 2D 欧几里得距离2. 批量形式(3D Tensor)3. 使用不

PostgreSQL 序列(Sequence) 与 Oracle 序列对比差异分析

《PostgreSQL序列(Sequence)与Oracle序列对比差异分析》PostgreSQL和Oracle都提供了序列(Sequence)功能,但在实现细节和使用方式上存在一些重要差异,... 目录PostgreSQL 序列(Sequence) 与 oracle 序列对比一 基本语法对比1.1 创建序

Java的栈与队列实现代码解析

《Java的栈与队列实现代码解析》栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,先进后出,分为栈底和栈顶,栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等,本文给大家介绍J... 目录栈的概念(Stack)栈的实现代码队列(Queue)模拟实现队列(双链表实现)循环队列(循环数组

Redis消息队列实现异步秒杀功能

《Redis消息队列实现异步秒杀功能》在高并发场景下,为了提高秒杀业务的性能,可将部分工作交给Redis处理,并通过异步方式执行,Redis提供了多种数据结构来实现消息队列,总结三种,本文详细介绍Re... 目录1 Redis消息队列1.1 List 结构1.2 Pub/Sub 模式1.3 Stream 结

SpringKafka错误处理(重试机制与死信队列)

《SpringKafka错误处理(重试机制与死信队列)》SpringKafka提供了全面的错误处理机制,通过灵活的重试策略和死信队列处理,下面就来介绍一下,具有一定的参考价值,感兴趣的可以了解一下... 目录引言一、Spring Kafka错误处理基础二、配置重试机制三、死信队列实现四、特定异常的处理策略五

Spring Boot整合消息队列RabbitMQ的实现示例

《SpringBoot整合消息队列RabbitMQ的实现示例》本文主要介绍了SpringBoot整合消息队列RabbitMQ的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目录RabbitMQ 简介与安装1. RabbitMQ 简介2. RabbitMQ 安装Spring

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque