当前位置: 首页 > news >正文

【洛谷 P1115】最大子段和 题解(贪心算法)

最大子段和

题目描述

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

输入格式

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

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

输出格式

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

样例 #1

样例输入 #1

7
2 -4 3 -1 2 -4 3

样例输出 #1

4

提示

样例 1 解释

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

数据规模与约定

  • 对于 40 % 40\% 40% 的数据,保证 n ≤ 2 × 1 0 3 n \leq 2 \times 10^3 n2×103
  • 对于 100 % 100\% 100% 的数据,保证 1 ≤ n ≤ 2 × 1 0 5 1 \leq n \leq 2 \times 10^5 1n2×105 − 1 0 4 ≤ a i ≤ 1 0 4 -10^4 \leq a_i \leq 10^4 104ai104

思路

在遍历数组a时,累加每个元素的值,并在每次更新ans时使用max函数选择当前最大的子段和。

同时,如果当前的子段和sum小于0,则说明当前的子段对后面的结果没有贡献,因此将sum重置为0,从下一个元素重新开始计算。


AC代码

#include <iostream>
#include <algorithm>
#define AUTHOR "HEX9CF"
using namespace std;const int maxn = 2e5 + 5;int main()
{int n;int a[maxn];int sum, ans;cin >> n;sum = 0;for (int i = 0; i < n; i++){cin >> a[i];if (!i){ans = a[0];}sum += a[i];ans = max(ans, sum);if (sum < 0){sum = 0;}}cout << ans << endl;return 0;
}
http://www.lryc.cn/news/164021.html

相关文章:

  • uni-app--》基于小程序开发的电商平台项目实战(一)
  • 入门人工智能 —— 学习一门编程语言 python 基础代码编写和运算符介绍(1)
  • 【java安全】CommonsBeanUtils1
  • JVM优化(OOM,内存溢出),查看线程快照,堆内存情况等问题
  • git 给分支添加描述
  • SpringBoot+Vue 整合websocket实现简单聊天窗口
  • PCB layout在布线上的设计规范有哪些?
  • 喜报丨迪捷软件入选浙江省2023年省级产业数字化服务商
  • verilog写rom,采用端口排序顺序例化
  • 基于SSM的共享客栈管理系统的设计与实现
  • 全屏Activity弹出键盘不顶起布局
  • JAVA设计模式详解 解构设计模式思想 详细代码对比
  • lintcode 567 · 最大得分 【动态规划 中等 】
  • qml嵌入到QWidget的两种方式介绍
  • Mysql数据库之常用SQL语句及事务学习总结
  • RuoYi若依管理系统最新版 基于SpringBoot的权限管理系统
  • html实现邮件模版布局-flex布局table布局-demo
  • CENTOS7安装redis在/home/pms/software路径下,并且将redis加入到systemctl中
  • 数据库笔记
  • AI是风口还是泡沫?
  • echarts环图配置
  • Redis优化 RDB AOF持久化
  • 三维模型3DTILE格式轻量化压缩主要技术方法浅析
  • c++day2---9.7
  • 地震反演基础知识2(代码演示)
  • C#学习 - 方法的定义、调用、调试
  • 『PyQt5-Qt Designer篇』| 09 Qt Designer中分割线和间隔如何使用?
  • 基于springboot2+mybatis-plus+jsp增删改查
  • [PHP]empty一直返回true
  • [2023.09.11]: Yew的SSR中的Cargo.toml配置