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

解题思路

本题等价于把正整数 nnn 划分为恰好 kkk 个正整数的有序序列。直接的划分型动态规划如下:

设 dp[s][t] 表示用恰好 t 枚硬币,面额之和为 s 的有序方案数。 转移时,最后一枚硬币取值为 x (1 ≤ x ≤ s),那么前面 t-1 枚的和是 s-x,于是:

dp[s][t]=∑x=1sdp[s−x][t−1]dp[s][t] = \sum_{x=1}^{s} dp[s-x][t-1]dp[s][t]=x=1∑s​dp[s−x][t−1]

P3900.兑换硬币

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

题面描述

给定两个正整数 n,kn,kn,k。你有面额为 1,2,3,…,1091,2,3,\ldots,10^91,2,3,…,109 的硬币,每种面额数量无限。你必须恰好选出 kkk 枚硬币,并且要求它们的总面额之和为 nnn。 选择的顺序不同视为不同方案(如 2,12,12,1 与 1,21,21,2 记为两种)。求满足条件的方案数;

输入输出

输入: 一行两个整数 n,kn,kn,k。

输出: 输出一个整数,表示恰好用 kkk 枚硬币凑成面额 nnn 的方案数。

数据范围

  • 1≤n≤631 \le n \le 631≤n≤63
  • 1≤k≤n1 \le k \le n1≤k≤n

样例

输入

3 2

输出

2

说明 可行序列:1,2,2,1。


输入

4 3

输出

3

说明 可行序列:1,1,2,1,2,1,2,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 1, 200ms
  3. Powered by Hydro v5.0.0-beta.18 Community
CLOSE


ScanQRCodePrompt

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

Forgot password or username?