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

解题思路

设 f(i)f(i)f(i) 为用若干个数(每次可取 1..i1..i1..i 中不超过剩余的整数)按顺序恰好凑成和为 iii 的方案数。最后一步取值为 t∈[1,i]t\in[1,i]t∈[1,i] 时,前缀必须凑成 i−ti-ti−t。因此有纯二重循环的 DP 递推:

实现上:

P3840.1+2+3+...+n问题

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

题面描述

本题在“每次取 1 或 2 凑成 nnn”与“每次取 1、2 或 3 凑成 nnn”的基础上进一步扩展: 给定一个非负整数 nnn。每次可取一个正整数,取值范围为 111 到 nnn,将若干个数相加恰好得到 nnn。两种方案只要在某个位置取的数不同,就视为不同(即顺序有区分)。求不同方案数。

记答案为 f(n)f(n)f(n)。

输入格式

  • 第一行一个整数 nnn。

输出格式

  • 输出一行一个整数:f(n)f(n)f(n)。

数据范围

  • 0≤n≤600 \le n \le 600≤n≤60

样例

样例输入

4

样例输出

8

说明

  • 对于 n=4n=4n=4,所有顺序不同的分解(每次可取 1..41..41..4,但不超过剩余)共有 8 种,分别是:
  1. 1+1+1+11+1+1+11+1+1+1
  2. 1+1+21+1+21+1+2
  3. 1+2+11+2+11+2+1
  4. 2+1+12+1+12+1+1
  5. 2+22+22+2
  6. 1+31+31+3
  7. 3+13+13+1
  8. 444

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


ScanQRCodePrompt

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

Forgot password or username?