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. 定义状态 我们定义一个数组 dpdpdp,其中 dp[i]dp[i]dp[i] 表示正整数 iii 有多少种不同的划分方案。我们的最终目标是求出 dp[n]dp[n]dp[n]。

  2. 状态转移方程 为了计算 dp[i]dp[i]dp[i],我们可以考虑构成整数 iii 的划分中,最后一个加数是什么。这个加数可以是 1,2,3,…,i1, 2, 3, \ldots, i1,2,3,…,i 中的任意一个。

P3637.整数划分(无序版本)

    1000ms Tried: 199 Accepted: 82 Difficulty: 5
    算法与标签>动态规划

题目描述

一个正整数nnn可以表示成若干个正整数之和,形如:nnn = a1a_1a1​ + a2a_2a2​ + ⋯\cdots⋯ + aka_kak​,其中a1a_1a1​, a2a_2a2​, …\ldots…, aka_kak​是正整数,且不考虑加数的顺序(即顺序不同但组合相同视为同一种划分)。

这样的表示称为正整数nnn的一种划分。

现在给定一个正整数nnn,请求出 nnn 有多少种不同的划分方案,并输出方案数。

输入

共一行,包含一个整数nnn。

输出

共一行,包含一个整数,表示总划分数量。

示例1

输入:

3

输出:

4

提示

对于n=3n = 3n=3,划分方案有:

  • 333
  • 2+12 + 12+1
  • 1+21 + 21+2
  • 1+1+11 + 1 + 11+1+1

示例2

输入:

4

输出:

8

提示

对于n=4n = 4n=4,划分方案有:

  • 444
  • 3+13 + 13+1
  • 1+31 + 31+3
  • 2+22 + 22+2
  • 1+1+21 + 1 + 21+1+2
  • 2+1+12 + 1 + 12+1+1
  • 1+2+11 + 2 + 11+2+1
  • 1+1+1+11 + 1 + 1 + 11+1+1+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 3, 35ms
  3. Powered by Hydro v5.0.0-beta.18 Community
CLOSE


ScanQRCodePrompt

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

Forgot password or username?