[算法][递归] 整数划分 种类数

简介:


 

在整数n的所有不同划分中,将最大加数n1不大于m的划分个数记为q(n,m),则q的递推关系式为: 

复制代码
 1 #include<iostream>
 2 using namespace std;
 3 int q(int n,int m){
 4     if((n<1)||(m<1))return 0;
 5     if((n==1)||(m==1))return 1;
 6     if(n<m)return q(n,n);
 7     if(n==m)return q(n,m-1)+1;
 8     return q(n,m-1)+q(n-m,m);
 9 }//递归函数
10 int main(){
11     int n;
12     cout<<"请输入整数 n = ";
13     while(cin>>n){
14         cout<<n<<" 的划分数量为 : "<<q(n,n)<<'\n';
15     }return 0;
16 }
复制代码
目录
打赏
0
0
0
0
23
分享
相关文章
|
8天前
|
算法系列之递归反转单链表
递归反转链表的基本思路是将当前节点的next指针指向前一个节点,然后递归地对下一个节点进行同样的操作。递归的核心思想是将问题分解为更小的子问题,直到达到基本情况(通常是链表末尾)。
31 5
算法系列之递归反转单链表
|
9月前
|
算法笔记:递归(c++实现)
算法笔记:递归(c++实现)
|
4月前
|
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果;贪心算法在每一步选择局部最优解,追求全局最优;动态规划通过保存子问题的解,避免重复计算,确保全局最优。这三种算法各具特色,适用于不同类型的问题,合理选择能显著提升编程效率。
91 2
数据结构与算法学习十二:希尔排序、快速排序(递归、好理解)、归并排序(递归、难理解)
这篇文章介绍了希尔排序、快速排序和归并排序三种排序算法的基本概念、实现思路、代码实现及其测试结果。
89 1
数据结构与算法学习九:学习递归。递归的经典实例:打印问题、阶乘问题、递归-迷宫问题、八皇后问题
本文详细介绍了递归的概念、重要规则、形式,并展示了递归在解决打印问题、阶乘问题、迷宫问题和八皇后问题等经典实例中的应用。
82 0
第一周算法设计与分析:C : 200和整数对之间的情缘
这篇文章介绍了解决算法问题"200和整数对之间的情缘"的方法,通过统计数组中每个数模200的余数,并计算每个同余类中数的组合数来找出所有满足条件的整数对(i, j),使得AiAj是200的整数倍。
|
7月前
|
【算法】递归、搜索与回溯——汉诺塔
【算法】递归、搜索与回溯——汉诺塔
(六)JVM成神路之GC基础篇:对象存活判定算法、GC算法、STW、GC种类详解
经过前面五个章节的分析后,对于JVM的大部分子系统都已阐述完毕,在本文中则开始对JVM的GC子系统进行全面阐述,GC机制也是JVM的重中之重,调优、监控、面试都逃不开的JVM话题。
247 8
|
8月前
|
python中算法递归错误(Recursion Errors)
【7月更文挑战第18天】
123 1

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等