news 2026/4/16 10:13:08

GESP认证C++编程真题解析 | P11963 [GESP202503 六级] 环线

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
GESP认证C++编程真题解析 | P11963 [GESP202503 六级] 环线

​欢迎大家订阅我的专栏:算法题解:C++与Python实现!
本专栏旨在帮助大家从基础到进阶 ,逐步提升编程能力,助力信息学竞赛备战!

专栏特色
1.经典算法练习:根据信息学竞赛大纲,精心挑选经典算法题目,提供清晰的代码实现与详细指导,帮助您夯实算法基础。
2.系统化学习路径:按照算法类别和难度分级,从基础到进阶,循序渐进,帮助您全面提升编程能力与算法思维。

适合人群:

  • 准备参加蓝桥杯、GESP、CSP-J、CSP-S等信息学竞赛的学生
  • 希望系统学习C++/Python编程的初学者
  • 想要提升算法与编程能力的编程爱好者

附上汇总帖:GESP认证C++编程真题解析 | 汇总


【题目来源】

洛谷:P11963 [GESP202503 六级] 环线 - 洛谷

【题目描述】

小 A 喜欢坐地铁。地铁环线有n nn个车站,依次以1 , 2 , ⋯ , n 1,2,⋯,n1,2,,n标号。车站i ( 1 ≤ i < n ) i (1≤i<n)i(1i<n)的下一个车站是车站i + 1 i+1i+1。特殊地,车站n nn的下一个车站是车站1 11

小 A 会从某个车站出发,乘坐地铁环线到某个车站结束行程,这意味着小 A 至少会经过一个车站。小 A 不会经过一个车站多次。当小 A 乘坐地铁环线经过车站i ii时,小 A 会获得a i a_iai点快乐值。请你安排小 A 的行程,选择出发车站与结束车站,使得获得的快乐值总和最大。

【输入】

第一行,一个正整数n nn,表示车站的数量。

第二行,n nn个整数a i a_iai,分别表示经过每个车站时获得的快乐值。

【输出】

一行,一个整数,表示小 A 能获得的最大快乐值。

【输入样例】

4 -1 2 3 0

【输出样例】

5

【算法标签】

《洛谷 P11963 环线》 #单调队列# #GESP# #2025#

【代码详解】

#include<bits/stdc++.h>usingnamespacestd;#defineintlonglong// 定义宏,将int替换为long long类型constintN=200005;// 定义数组的最大大小intn;// 输入的数字个数inta[N*2];// 存储输入的数字,并复制一份实现环形处理intsa[N*2];// 前缀和数组intmaxn=-2e18;// 记录最大子段和,初始化为极小值intq[N*2];// 单调队列,用于维护窗口最小值signedmain(){cin>>n;// 输入数字个数// 输入数字并复制一份实现环形处理for(inti=1;i<=n;i++){intx;cin>>x;a[i]=x;a[i+n]=x;// 复制一份,实现环形数组}// 计算前缀和数组for(inti=1;i<=2*n;i++){sa[i]=sa[i-1]+a[i];}// 初始化单调队列inthh=0,tt=-1;// 队列头尾指针// 遍历前缀和数组,寻找最大子段和for(inti=1;i<=2*n;i++){// 维护窗口大小不超过nwhile(hh<=tt&&q[hh]<i-n)hh++;// 计算当前窗口的最大子段和if(hh<=tt){maxn=max(maxn,sa[i]-sa[q[hh]]);}// 维护单调递增队列while(hh<=tt&&sa[q[tt]]>=sa[i])tt--;q[++tt]=i;}cout<<maxn<<endl;// 输出最大子段和return0;}

【运行结果】

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

救命神器2026继续教育TOP10AI论文写作软件测评与推荐

救命神器2026继续教育TOP10AI论文写作软件测评与推荐 2026年继续教育领域AI论文写作工具测评维度解析 随着人工智能技术的不断进步&#xff0c;AI写作工具在学术研究与继续教育领域的应用日益广泛。然而&#xff0c;面对市场上琳琅满目的产品&#xff0c;如何选择真正适合自身需…

作者头像 李华
网站建设 2026/4/13 21:14:07

《jQuery UI 简介》

《jQuery UI 简介》 引言 jQuery UI 是一个基于 jQuery 的用户界面库,它提供了丰富的交互组件和效果,可以帮助开发者快速构建出美观且功能强大的网页应用。本文将为您详细介绍 jQuery UI 的基本概念、特性以及如何在实际项目中使用它。 jQuery UI 简介 1. 什么是 jQuery …

作者头像 李华
网站建设 2026/4/10 7:27:11

NumPy 位运算详解

NumPy 位运算详解 引言 在数值计算中&#xff0c;位运算是一种基本的操作&#xff0c;特别是在处理大量数据时。NumPy&#xff0c;作为Python中处理数值计算的强大库&#xff0c;提供了丰富的位运算功能。本文将详细探讨NumPy中的位运算&#xff0c;包括位与、位或、位异或、位…

作者头像 李华
网站建设 2026/4/15 18:31:49

GESP认证C++编程真题解析 | P11960 [GESP202503 五级] 平均分配

​欢迎大家订阅我的专栏&#xff1a;算法题解&#xff1a;C与Python实现&#xff01; 本专栏旨在帮助大家从基础到进阶 &#xff0c;逐步提升编程能力&#xff0c;助力信息学竞赛备战&#xff01; 专栏特色 1.经典算法练习&#xff1a;根据信息学竞赛大纲&#xff0c;精心挑选…

作者头像 李华