news 2026/5/12 21:03:02

洛谷 T478345:循环数组 ← 单调队列 + 破环成链

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
洛谷 T478345:循环数组 ← 单调队列 + 破环成链

【题目来源】
https://www.luogu.com.cn/problem/T478345

【题目描述】
给你一个循环的数组 A[1], A[2], A[3], ...., A[n]。循环的数组意思是 A[1] 的左边是 A[n],A[n] 的右边是 A[1],也就是可以理解为他们连成了一个环。
现在你的任务是找到一个字串( A[1,2,3] 算子串,A[n-1,n,1,2] 也算,但是必须连续,A[1,3,4] 则不算),这个子串要求长度小于等于 K。在这个要求下,子串的元素和最大能是多少?
注意子串不能为空。1<=N<=1000000,1<=K<=N,-1000<=A[i]<=1000

【输入格式】
第一行两个整数,N,K,空格隔开。
接下来一行 N 个数,空格隔开,为数组元素 A[1] ... A[n]。​​​​​​​

【输出格式】
输出一行,为一个整数,代表最大和。

【输入样例】
6 3
6 -1 2 -6 5 -5

【输出样例】
7

【数据范围】
1<=N<=1000000,1<=K<=N,-1000<=A[i]<=1000​​​​​​​​​​​​​​

【算法分析】
● 环形数组的经典处理技巧:
破环成链,将原数组拼接一份,得到长度为 2N 的数组,原环形的任意连续子串都对应新数组的一段长度 ≤K 的连续子串。
● 前缀和 + 单调队列优化:利用前缀和将「区间和」转化为「两个前缀和的差值」,用单调队列维护前缀和的最小值,从而在 O(N) 时间内找到最优解。

【算法代码】

#include <bits/stdc++.h> using namespace std; typedef long long LL; const int maxn=1e6+5; LL imax=LLONG_MIN; LL s[maxn<<1]; //presum int a[maxn]; int main() { ios::sync_with_stdio(0); cin.tie(0); cout.tie(0); int n,k; cin>>n>>k; for(int i=1; i<=n; i++) { cin>>a[i]; } for(int i=1; i<=n+k; i++) { //破环成链 s[i]=s[i-1]+a[(i-1)%n+1]; //环形取数 } deque<int> q; //单调队列存下标,保证s[下标]单调递增 q.push_back(0); for(int i=1; i<=n+k-1; i++) { while(!q.empty() && q.front()<i-k) { q.pop_front(); } if(!q.empty()) { imax=max(imax,s[i]-s[q.front()]); } while(!q.empty() && s[i]<=s[q.back()]) { q.pop_back(); } q.push_back(i); } cout<<imax<<endl; return 0; } /* in: 6 3 6 -1 2 -6 5 -5 out: 7 */





【参考文献】
​​​​​​​
https://blog.csdn.net/hnjzsyjyj/article/details/143176072
https://www.luogu.com.cn/problem/T478345







版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/12 2:47:13

数据库核心概念深度解析:从基础原理到 SQL 分类

数据库核心概念深度解析&#xff1a;从基础原理到 SQL 分类作为一名技术从业者&#xff0c;无论是网络工程师转型、后端开发入门&#xff0c;还是数据相关岗位学习&#xff0c;数据库都是绕不开的核心技能。本文将系统性拆解数据库的核心概念&#xff0c;涵盖数据库与 DBMS 定义…

作者头像 李华
网站建设 2026/4/25 18:45:16

Hot100——栈

有效的括号给定一个只包括 (&#xff0c;)&#xff0c;{&#xff0c;}&#xff0c;[&#xff0c;] 的字符串 s &#xff0c;判断字符串是否有效。有效字符串需满足&#xff1a;左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。每个右括号都有一个对应的相同类型…

作者头像 李华
网站建设 2026/5/3 13:44:37

Flutter---时间核心类

DateTime - 基础时间类// 创建 DateTime 对象 DateTime now DateTime.now(); // 当前时间 DateTime specific DateTime(2024, 1, 15); // 指定日期 (年,月,日) DateTime detailed DateTime(2024, 1, 15, 10, 30); // 指定日期时间 (年,月,日,时,分…

作者头像 李华
网站建设 2026/4/23 10:45:49

aa---(6)

26.My EasterFocus QuestionWhat does the girl do on Easter?basket Easter(复活节) candy eggs dress familytextMy dress.My hat.My basket.My eggs.My candy.My flowers.My family.My Easter.ConnectionsEaster is a holiday.What are other holidays&#xff1f;Make a l…

作者头像 李华
网站建设 2026/4/23 12:16:16

53、UART 串口通信

UART 串口通信&#xff08;51单片机Modbus协议&#xff09; 一、UART 核心概念与特性 UART&#xff08;Universal Asynchronous Receiver Transmitter&#xff09; 通用异步收发器&#xff0c;是MCU与外部设备异步通信的硬件接口模块&#xff0c;核心特性如下&#xff1a; 异步…

作者头像 李华
网站建设 2026/5/10 3:04:18

电力电子工程师简历优化指南:从“简历泥潭”到入职邀约,只需三招

为什么你的技术简历总石沉大海&#xff1f;痛点切入&#xff1a;据技术招聘平台数据&#xff0c;超过 68% 的电力电子工程师简历&#xff0c;在招聘方初筛时的停留时间不足 15 秒。这些简历普遍存在“技术堆砌、成果模糊、价值迷失”的泥潭&#xff0c;如同一位只会展示所有扳手…

作者头像 李华