博客
关于我
递推算法——例题详解
阅读量:788 次
发布时间:2019-03-24

本文共 1445 字,大约阅读时间需要 4 分钟。

递推算法的本质

递推算法的本质是通过将复杂问题分解为多个较小的问题并建立彼此之间的数字关系,将问题一步步简化求解。在递推过程中,我们通过已知部分问题的结果,逐步推导出未知部分的问题解,类似于从下而上解决问题的方式,使得问题变得更加清晰和可控。

例一:数塔问题(倒推法)

数塔问题是递推算法的经典例子。问题描述为:在一个由数字构成的数塔中,从顶部到底部找出一条路径,使得路径上的数字之和最大。解决这个问题的常用方法是倒推法,即从上层向下层推导。

分析:将问题从上而下分解显然并不直观,因此我们选择从下而上进行分析。通过观察我们可以发现,每一层的数字之和等于下一层中与其相邻的两个数字中较大的那个加上当前层的数字。

最终,从最底层到最顶层,我们逐步计算每层的值,从而得到最大和路径。

代码实现:

#include 
#include
#include
#include
using namespace std;int main() { int n, i, j; char a[101][101]; cin >> n; for (i = 1; i <= n; ++i) { for (j = 1; j <= i; ++j) { cin >> a[i][j]; } } for (i = n - 1; i >= 1; --i) { for (j = 1; j <= i; ++j) { if (a[i + 1][j] >= a[i + 1][j + 1]) { a[i][j] += a[i + 1][j]; } else { a[i][j] += a[i + 1][j + 1]; } } } cout << a[1][1] << endl; return 0;}

例二:斐波那契数列的非递归实现

斐波那契数列是一个经典的递推序列,其定义为:f(0)=1,f(1)=1,f(n)=f(n-1)+f(n-2)。通过递推式,我们可以逐步计算出后续的数列项。

分析:观察数列的结构,我们可以发现每一项都等于前两项之和。通过非递归的方式,我们可以通过循环实现,将前一项和前前一项的值相加,逐步生成数列。

代码实现:

#include 
#include
#include
#include
using namespace std;int main() { int f0 = 1, f1 = 1, f2 = 2; int n; cin >> n; for (int i = 3; i <= n; ++i) { f2 = f0 + f1; f0 = f1; f1 = f2; } cout << f2; return 0;}

其他相关类型的问题

类似的递推类型问题还包括经典的蓝桥杯题目“奶牛问题”等,其中涉及递归和非递归的不同实现方法。

转载地址:http://phrkk.baihongyu.com/

你可能感兴趣的文章
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现update数据实时同步_实际操作05---大数据之Nifi工作笔记0044
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从Oracle11G同步数据到Mysql_亲测可用_解决数据重复_数据跟源表不一致的问题---大数据之Nifi工作笔记0065
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
NIFI同步MySql数据源数据_到原始库hbase_同时对数据进行实时分析处理_同步到清洗库_实际操作06---大数据之Nifi工作笔记0046
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_实际操作---大数据之Nifi工作笔记0020
查看>>