洛谷 P1115 最大子段和
创始人
2024-05-29 18:39:31

题目链接:P1115 最大子段和 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

题目描述

给出一个长度为 n 的序列 a,选出其中连续且非空的一段使得这段和最大。

输入格式

第一行是一个整数,表示序列的长度 n。

第二行有 n 个整数,第 i 个整数表示序列的第 i 个数字 ai。

输出格式

输出一行一个整数表示答案。

样例 #1

样例输入 #1

7
2 -4 3 -1 2 -4 3

样例输出 #1

4

提示

样例 1 解释

选取 [3, 5] 子段 {3, -1, 2},其和为 4。

数据规模与约定

  • 对于 40% 的数据,保证 n ≤ 2 × 10^3。
  • 对于 100% 的数据,保证 1 ≤ n ≤ 2 × 10^5,−10^4 ≤ ai ≤ 10^4。

AC code 1:(动态规划,线性dp)——使用dp数组存放每一个状态

#include
#include
#includeusing namespace std;int main()
{int n;cin>>n;vector a(n);for(int i = 0 ; i < n ; i ++)cin>>a[i];vector dp(n); // dp[i] 表示以下标 i 结尾的最大字段和dp[0] = a[0];int res = dp[0];for(int i = 1 ; i < n ; i ++){dp[i] = max(dp[i - 1] + a[i] , a[i]);res = max(res , dp[i]);}cout<

AC code 2: (发现每次只需要使用上一个状态(dp[i - 1]),因此可以直接使用一个变量保存上一个状态即可,减少额外的空间开销)

#include
#include
#includeusing namespace std;int main()
{int n;cin>>n;vector a(n);for(int i = 0 ; i < n ; i ++)cin>>a[i];int temp = a[0];int res = temp;for(int i = 1 ; i < n ; i ++){temp = max(temp + a[i] , a[i]);res = max(res , temp);}cout<

当然,这题也可以使用更为精妙的“分治”思想求解。

相关内容

热门资讯

利好来了!6G概念股,批量涨停... 【导读】北证50指数半日大涨6.74%,6G概念股震荡拉升,个股掀“涨停潮”中国基金报记者  张舟6...
悦读·思享丨变局下的中国方案:... ——评《“一带一路”建设与国际经贸规则研究》 ■张幼文共建“一带一路”倡议是我国在新时代实行高水平对...
什么牌子的素颜霜好用?2026... 对于绝大多数追求高效护肤的人来说,挑选素颜霜的核心诉求始终很直白:一瓶搞定全脸底妆、省去隔离遮瑕步骤...
江苏:苏州这里禁止新建项目迁入... (来源:上观新闻)近日,江苏省政府发布《关于禁止在江苏省太湖流域太湖东片排涝工程建设范围内新增建设项...
男子高铁上用电风扇被劝阻 目击... 【#男子高铁上用电风扇被劝阻# 目击者:车厢不热,自己第一次见】#12306回应旅客用电风扇被劝阻#...