整数的所有不同分割数目--非递归算法

简介:
     思路:非递归与递归的思维顺序是互逆的,所以很容易写出以下代码。
 1 #include <stdio.h>
 2 #define MAX 1000
 3 
 4 int p[MAX][MAX]={0};
 5 
 6 int main()
 7 {
 8     int n=2;    
 9     int index_n,index_m;
10     //initialize the p[n][1]=1;
11     for(index_n=1;index_n<=n;index_n++)
12         p[index_n][1]=1;
13 
14     //initialize the p[1][m]=1;
15     int m=n;
16     for(index_m=1;index_m<=m;index_m++)
17         p[1][index_m]=1;
18 
19     for(index_n=2;index_n<=n;index_n++)
20     {
21         for(index_m=2;index_m<index_n;index_m++)
22         {
23             p[index_n][index_m]=p[index_n][index_m-1]+p[index_n-index_m][index_m];
24         }
25         //index_m==index_n,ie,m==n
26         p[index_n][index_m]=1+p[index_n][index_m-1];
27     }
28     printf("%d\n",p[n][n]);
29     return 0;
30 }
 
本文转自NeilHappy 51CTO博客,原文链接:http://blog.51cto.com/neilhappy/1133845,如需转载请自行联系原作者
相关文章
|
自然语言处理 Rust 算法
【算法】13. 罗马数字转整数(多语言实现)
罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。 | 字符 | 数值 | |--|--| | I | 1 | | V | 5 | | X | 10 | | L | 50 | | C | 100 | | D | 500 | | M | 1000 | 例如, 罗马数字 2 写做 II ,即为两个并列的 1。12 写做 XII ,即为 X + II 。 27 写做 XXVII, 即为 XX + V + II 。 通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII,而是 IV。数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1
【算法】13. 罗马数字转整数(多语言实现)
|
算法 测试技术 C#
【数位dp】【C++算法】600. 不含连续1的非负整数
【数位dp】【C++算法】600. 不含连续1的非负整数
|
机器学习/深度学习 监控 算法
yolov8+多算法多目标追踪+实例分割+目标检测+姿态估计(代码+教程)
yolov8+多算法多目标追踪+实例分割+目标检测+姿态估计(代码+教程)
|
算法 Java
[Java·算法·简单] LeetCode 13. 罗马数字转整数 详细解读
[Java·算法·简单] LeetCode 13. 罗马数字转整数 详细解读
160 0
|
3月前
|
canal 算法 vr&ar
【图像处理】基于电磁学优化算法的多阈值分割算法研究(Matlab代码实现)
【图像处理】基于电磁学优化算法的多阈值分割算法研究(Matlab代码实现)
123 1
|
9月前
|
算法
一次推理,实现六大3D点云分割任务!华科发布大一统算法UniSeg3D,性能新SOTA
华中科技大学研究团队提出了一种名为UniSeg3D的创新算法,该算法通过一次推理即可完成六大3D点云分割任务(全景、语义、实例、交互式、指代和开放词汇分割),并基于Transformer架构实现任务间知识共享与互惠。实验表明,UniSeg3D在多个基准数据集上超越现有SOTA方法,为3D场景理解提供了全新统一框架。然而,模型较大可能限制实际部署。
666 15
|
人工智能 算法
第一周算法设计与分析:C : 200和整数对之间的情缘
这篇文章介绍了解决算法问题"200和整数对之间的情缘"的方法,通过统计数组中每个数模200的余数,并计算每个同余类中数的组合数来找出所有满足条件的整数对(i, j),使得\( A_i - A_j \)是200的整数倍。
|
算法 Java 索引
数据结构与算法学习十五:常用查找算法介绍,线性排序、二分查找(折半查找)算法、差值查找算法、斐波那契(黄金分割法)查找算法
四种常用的查找算法:顺序查找、二分查找(折半查找)、插值查找和斐波那契查找,并提供了Java语言的实现代码和测试结果。
232 0
|
算法
【算法】二分查找(整数二分和浮点数二分)
算法学习——二分查找(整数二分和浮点数二分)
199 0
【算法】二分查找(整数二分和浮点数二分)
|
算法 计算机视觉 Python
使用分水岭算法分割图像
【6月更文挑战第4天】使用分水岭算法分割图像。
669 4

热门文章

最新文章