1. Job Roadmap
  2. Home
  3. Problem Set
  4. codenotelist
  5. Forum
  6. course
  7. Shore Share Sessions
  8. Record
  1. Login
  2. Sign Up
  3. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
    ZhContent TextSol video solution AI分析

题解思路

状态机动态规划建模

本题可以看作是一个状态机 DP问题,每个下标 i 都有两种状态:

  • 状态 s1(i)s_1(i)s1​(i):必须以下标 iii 结尾的子段最大和 即当前子段必须包含 aia_iai​,对应 dp[i][1]。
  • 状态 s0(i)s_0(i)s0​(i):前 iii 个元素中的全局最大子段和

P3905.最大子段和

    1000ms Tried: 108 Accepted: 51 Difficulty: 4
    算法与标签>动态规划

题目描述:

给定一个整数序列 a1,a2,…,ana_1, a_2, \dots, a_na1​,a2​,…,an​,其中 nnn 为整数序列的长度。请你计算出该序列的最大子段和,即从该序列中选出一个连续的子序列,使得子序列的和最大。请注意,子序列的长度可以为 1,且可以是整个序列。

输入:

输入的第一行包含一个整数 nnn (1≤n≤105)(1 \leq n \leq 10^5)(1≤n≤105),表示序列的长度。

输入的第二行包含 nnn 个整数 a1,a2,…,ana_1, a_2, \dots, a_na1​,a2​,…,an​ (−104≤ai≤104)(-10^4 \leq a_i \leq 10^4)(−104≤ai​≤104),表示序列中的元素。

输出:

输出一个整数,表示最大子段和。

样例输入:

9
-2 1 -3 4 -1 2 1 -5 4

样例输出:

6

提示:

在上面的例子中,最大子段和为 6,对应的子序列为 [4,−1,2,1][4, -1, 2, 1][4,−1,2,1]。

开通会员即可查看完整视频题解: 1.题目讲解 2.思路分析 3.逐行代码手写

登录后即可使用 AI 分析。

模式
倒计时时长
:

最长 10 小时 59 分;应用后按此时长重新开始。

提示:点击提交记录在左侧题面区域查看详情
题库
AI分析设置
留空使用官方API Key,每天有次数限制(自定义API Key仅限会员和管理员使用,不限次数)
会员和管理员可切换模型;切到 Kimi/智谱/通义/豆包时需填写对应供应商 API Key
升级会员,可将运行与提交冷却时间缩短至 1 秒起

Status

  • Judging Queue
  • Service Status

Development

  • Open Source

Support

  • Help
  • Contact Us

About

  • About
  • Privacy
  • Terms of Service
  • Copyright Complaint
  1. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
  2. Legacy mode
  3. Theme
    1. Light
    2. Dark
  1. 京ICP备2025123107号-1
  2. Worker 1, 30ms
  3. Powered by Hydro v5.0.0-beta.18 Community
CLOSE


ScanQRCodePrompt

请使用微信扫描下方二维码完成注册

Forgot password or username?