问题描述 :

  有 n 个无区别的物品 , 将他们分成 不超过 m 堆, 问有多少种分法 ?  

例如 :

  n = 4 , m = 3 , 则总共有的分法是 1 + 2 +1 , 0 + 1 + 3 , 0 + 2 + 2 , 0 + 0 +  4 。

  共有 4 种分法 ,观察这四种分法 , 有一个特点 , 即 带 0 的划分 和不带 0 的划分 ,首先不带 0 的划分 , 比如 1 + 2 + 1 就可以视为是 0 + 1 + 0 的划分数递推加 1 得到的 , 带 0 的划分就可以视为是 将 n 分为 m - 1 份所得到的划分数 。

代码示例 :

  1. int n, m;
  2. int dp[100][100];
  3.  
  4. int main() {
  5. //freopen("in.txt", "r", stdin);
  6. //freopen("out.txt", "w", stdout);
  7.  
  8. cin >> n >> m;
  9. dp[0][0] = 1;
  10. for(int i = 1; i <= m; i++) dp[0][i] = 1;
  11.  
  12. for(int i = 1; i <= n; i++){
  13. for(int j = 1; j <= m; j++){
  14. if (i >= j) dp[i][j] = dp[i-j][j]+dp[i][j-1];
  15. else dp[i][j] = dp[i][j-1];
  16. }
  17. }
  18. cout << dp[n][m] << endl;
  19. return 0;
  20. }

将数字 n 分成不超过 m 份的方案数

dp[i][j] 表示将数字 i 分成 j 份的方案数,转移的话分为两种,

第一种是 假设其中有某一堆的个数为 1 , 则可以有 dp[i-1][j-1] 推来

第二种是 假设其中所有堆的个数都大于等于 2, 则可以由 dp[i-j][j] 推来

  1. int n, m;
  2. int dp[205][100];
  3.  
  4. int main() {
  5. //freopen("in.txt", "r", stdin);
  6. //freopen("out.txt", "w", stdout);
  7.  
  8. cin >> n >> m;
  9. dp[0][0] = 1;
  10.  
  11. for(int i = 1; i <= n; i++){
  12. for(int j = 1; j <= m; j++){
  13. if (i >= j) dp[i][j] = dp[i-j][j]+dp[i-1][j-1];
  14. }
  15. }
  16. cout << dp[n][m] << endl;
  17. return 0;
  18. }

dp-划分数 (递推)的更多相关文章

  1. [AHOI2009]中国象棋 DP,递推,组合数

    DP,递推,组合数 其实相当于就是一个递推推式子,然后要用到一点组合数的知识 一道很妙的题,因为不能互相攻击,所以任意行列不能有超过两个炮 首先令f[i][j][k]代表前i行,有j列为一个炮,有k列 ...

  2. UVa 926【简单dp,递推】

    UVa 926 题意:给定N*N的街道图和起始点,有些街道不能走,问从起点到终点有多少种走法. 很基础的dp.递推,但是有两个地方需要注意,在标记当前点某个方向不能走时,也要同时标记对应方向上的对应点 ...

  3. HDU 5965 三维dp 或 递推

    题意:= =中文题 思路一:比赛时队友想的...然后我赛后想了一下想了个2维dp,但是在转移的时候,貌似出了点小问题...吧?然后就按照队友的思路又写了一遍. 定义dp[i][j][k],表示第i列, ...

  4. 大概是:整数划分||DP||母函数||递推

    整数划分问题 整数划分是一个经典的问题. Input 每组输入是两个整数n和k.(1 <= n <= 50, 1 <= k <= n) Output 对于每组输入,请输出六行. ...

  5. 【BZOJ4944】【NOI2017】泳池 概率DP 常系数线性递推 特征多项式 多项式取模

    题目大意 有一个\(1001\times n\)的的网格,每个格子有\(q\)的概率是安全的,\(1-q\)的概率是危险的. 定义一个矩形是合法的当且仅当: 这个矩形中每个格子都是安全的 必须紧贴网格 ...

  6. [NOI2017]泳池——概率DP+线性递推

    [NOI2017]泳池 实在没有思路啊~~~ luogu题解 1.差分,转化成至多k的概率减去至多k-1的概率.这样就不用记录“有没有出现k”这个信息了 2.n是1e9,感觉要递推然后利用数列的加速技 ...

  7. lightoj 1126 - Building Twin Towers(dp,递推)

    题目链接:http://www.lightoj.com/volume_showproblem.php?problem=1126 题解:一道基础的dp就是简单的递推可以设dp[height_left][ ...

  8. BZOJ5017 [Snoi2017]炸弹[线段树优化建边+scc缩点+DAG上DP/线性递推]

    方法一: 朴素思路:果断建图,每次二分出一个区间然后要向这个区间每个点连有向边,然后一个环的话是可以互相引爆的,缩点之后就是一个DAG,求每个点出发有多少可达点. 然后注意两个问题: 上述建边显然$n ...

  9. UVa 825【简单dp,递推】

    UVa 825 题意:给定一个网格图(街道图),其中有一些交叉路口点不能走.问从西北角走到东南角最短走法有多少种.(好像没看到给数据范围...) 简单的递推吧,当然也就是最简单的动归了.显然最短路长度 ...

  10. codeforces 696C PLEASE 概率dp+公式递推+费马小定理

    题意:有3个杯子,排放一行,刚开始钥匙在中间的杯子,每次操作,将左右两边任意一个杯子进行交换,问n次操作后钥匙在中间杯子的概率 分析:考虑动态规划做法,dp[i]代表i次操作后的,钥匙在中间的概率,由 ...

随机推荐

  1. 2019-10-19-dotnet-给MatterMost订阅RSS博客

    title author date CreateTime categories dotnet 给MatterMost订阅RSS博客 lindexi 2019-10-19 08:12:36 +0800 ...

  2. linux中添加常用应用程序的桌面图标

    在网上随处可以找到怎么样把应用程序的图标放到桌面上,我刚用ubuntu时也是按照网上的做法,一步一步的做的,现将网上的做法复制下来: 桌面配置文件简述\label{sec:desktop file} ...

  3. dotnet 使用 Qpush 快速从电脑到手机推送文字

    在手机打字总不是方便,于是就有了 Qpush 这个工具,通过这个工具可以快速从电脑到手机推送文字. 但是这个工具没有找到客户端,于是我就给他写了一个库,通过这个库可以快速进行开发 先介绍QPush 快 ...

  4. H3C 路由度量值(Metric)

  5. Linux 内核类设备

    一个类的真正目的是作为一个是该类成员的设备的容器. 一个成员由 struct class_device 来表示: struct class_device { struct kobject kobj; ...

  6. bash: : Too many levels of symbolic links

    ln -s 时 bash: : Too many levels of symbolic links改为绝对路径,

  7. 基于Nutch+Hadoop+Hbase+ElasticSearch的网络爬虫及搜索引擎

    基于Nutch+Hadoop+Hbase+ElasticSearch的网络爬虫及搜索引擎 网络爬虫架构在Nutch+Hadoop之上,是一个典型的分布式离线批量处理架构,有非常优异的吞吐量和抓取性能并 ...

  8. Channel 9视频整理【5】

    Jennifer Chiu https://channel9.msdn.com/Niners/JenniferChiu

  9. 苹果笔记本修改pycharm for mac 修改字体大小

    实在是隐藏的太深了,无语

  10. 如何使用IoTSharp对接ModBus?

    提到对接ModBus 那么或许大家最熟悉的可能是 HslCommunication 和SharpSCADA 了,是GitHub 上关注最多的此类开源项目,  因此IoTSharp将通过HSL组件进行数 ...