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分析

题解

令数组下标从 1 开始,x = nums[i]。定义三维状态:

  • dp[i][j][1]:处理到第 i 个元素后,已选 j 段,当前不在子段内 的最大和。
  • dp[i][j][2]:处理到第 i 个元素后,已选 j 段,当前位于第 j 段内 的最大和(且该段包含第 i 个元素)。

初始化(i=0 表示未处理任何元素):

P3694.最大K个子数组和

    1000ms Tried: 25 Accepted: 7 Difficulty: 6
    算法与标签>动态规划

题目描述

给定一个整数数组numsnumsnums和一个整数kkk,要求你从数组中找出 kkk 个不重叠的子数组,使得这 kkk 个子数组的元素和最大。注意,子数组的下标必须不重叠。

具体要求如下:

  1. 子数组的定义是数组的连续部分。

输入格式

  • 第一行输入两个整数 nnn 和 kkk (1≤n≤1001 ≤ n ≤ 1001≤n≤100, 1≤k≤n1 ≤ k ≤ n1≤k≤n),分别表示数组的长度和要选取的子数组数量。
  • 第二行输入 nnn 个整数,表示数组 numsnumsnums 的元素,元素值范围为 (−1000≤nums[i]≤1000-1000 ≤ nums[i] ≤ 1000−1000≤nums[i]≤1000)。

输出格式

  • 输出 kkk 个不重叠子数组和的最大值。

数据范围

  • 1≤n≤1001 ≤ n ≤ 1001≤n≤100
  • 1≤k≤n1 ≤ k ≤ n1≤k≤n
  • −1000≤nums[i]≤1000-1000 ≤ nums[i] ≤ 1000−1000≤nums[i]≤1000

示例

输入

6 2
1 -2 3 4 -1 2

输出

9

开通会员即可查看完整视频题解: 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 0, 25ms
  3. Powered by Hydro v5.0.0-beta.18 Community
CLOSE


ScanQRCodePrompt

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

Forgot password or username?