【算法】递归、搜索与回溯——简介

简介: 【算法】递归、搜索与回溯——简介

简介:递归、搜索与回溯,本节博客主要是简单记录一下关于“递归、搜索与回溯”的相关简单概念,为后续算法做铺垫。


递归、搜索、回溯的关系:

1.递归

1.1递归概念

函数自己调用自己

2.2递归意义

递归具有多种意义,比如二叉树的遍历、快排、归并…

本质:用于解决主问题的方法f,在子问题中也可以适用,即有限“套娃”

2.3学习递归

  • 递归展开图
  • 多练习题目
  • 宏观看待递归过程
  • 不要在意递归细节展开
  • 将递归函数看成一个黑盒
  • 认为黑盒可以解决此问题

2.4写递归代码步骤

递归代码往往比较简短,但是要注意思考的步骤:

  • 1.函数头的设计:找相同的子问题,根据需要设计参数
  • 2.函数体的编写:只关心一个子问题的解决方案
  • 3.函数结束:注意递归结束条件

2.搜索

搜索 分为深度 优先搜索(dfs)广度搜索(bfs) ,仍属于暴力遍历

以二叉树为例,来解释dfs与bfs:

dfs:

bfs:

拓展:全排列问题也可以用深度优先遍历来进行解决。

例如:

3.回溯与剪枝

回溯:尝试某种情况发现走不通所进行的回到最近分界点的过程。

剪纸:当通过会u是回到分界点时,已经确定某一条鲁不具有可行性,从而排除这种选择称之为剪枝。


EOF


相关文章
|
23天前
|
存储 算法 调度
基于和声搜索优化算法的机器工作调度matlab仿真,输出甘特图
本程序基于和声搜索优化算法(Harmony Search, HS),实现机器工作调度的MATLAB仿真,输出甘特图展示调度结果。算法通过模拟音乐家即兴演奏寻找最佳和声的过程,优化任务在不同机器上的执行顺序,以最小化完成时间和最大化资源利用率为目标。程序适用于MATLAB 2022A版本,运行后无水印。核心参数包括和声记忆大小(HMS)等,适应度函数用于建模优化目标。附带完整代码与运行结果展示。
|
19天前
|
人工智能 自然语言处理 算法
阿里云 AI 搜索开放平台:从算法到业务——AI 搜索驱动企业智能化升级
本文介绍了阿里云 AI 搜索开放平台的技术的特点及其在各行业的应用。
120 3
|
3月前
|
机器学习/深度学习 算法
算法系列之搜索算法-深度优先搜索DFS
深度优先搜索和广度优先搜索一样,都是对图进行搜索的算法,目的也都是从起点开始搜索,直到到达顶点。深度优先搜索会沿着一条路径不断的往下搜索,直到不能够在继续为止,然后在折返,开始搜索下一条候补路径。
140 62
算法系列之搜索算法-深度优先搜索DFS
|
2月前
|
算法 Java
算法系列之回溯算法求解数独及所有可能解
数独求解的核心算法是回溯算法。回溯算法是一种通过逐步构建解决方案并在遇到冲突时回退的算法。具体来说,我们尝试在空格中填入一个数字,然后递归地继续填充下一个空格。如果在某个步骤中发现无法继续填充,则回退到上一步并尝试其他数字。
69 11
算法系列之回溯算法求解数独及所有可能解
|
3月前
|
算法 Java
算法系列之回溯算法
回溯算法(Backtracking Algorithm)是一种通过穷举来解决问题的方法,它的核心思想是从一个初始状态出发,暴力搜索所有可能的解决方案,遇到正确解将其记录,直到找到了所有的解或者尝试了所有的可能为止。
50 4
算法系列之回溯算法
|
3月前
|
存储 算法 Java
算法系列之递归反转单链表
递归反转链表的基本思路是将当前节点的next指针指向前一个节点,然后递归地对下一个节点进行同样的操作。递归的核心思想是将问题分解为更小的子问题,直到达到基本情况(通常是链表末尾)。
56 5
算法系列之递归反转单链表
|
3月前
|
存储 算法
算法系列之搜索算法-广度优先搜索BFS
广度优先搜索(BFS)是一种非常强大的算法,特别适用于解决最短路径、层次遍历和连通性问题。在面试中,掌握BFS的基本实现和应用场景,能够帮助你高效解决许多与图或树相关的问题。
109 1
算法系列之搜索算法-广度优先搜索BFS
|
3月前
|
算法
基于SOA海鸥优化算法的三维曲面最高点搜索matlab仿真
本程序基于海鸥优化算法(SOA)进行三维曲面最高点搜索的MATLAB仿真,输出收敛曲线和搜索结果。使用MATLAB2022A版本运行,核心代码实现种群初始化、适应度计算、交叉变异等操作。SOA模拟海鸥觅食行为,通过搜索飞行、跟随飞行和掠食飞行三种策略高效探索解空间,找到全局最优解。
|
6月前
|
算法 Python
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果;贪心算法在每一步选择局部最优解,追求全局最优;动态规划通过保存子问题的解,避免重复计算,确保全局最优。这三种算法各具特色,适用于不同类型的问题,合理选择能显著提升编程效率。
120 2
|
6月前
|
算法 搜索推荐 数据库
二分搜索:高效的查找算法
【10月更文挑战第29天】通过对二分搜索的深入研究和应用,我们可以不断挖掘其潜力,为各种复杂问题提供高效的解决方案。相信在未来的科技发展中,二分搜索将继续发挥着重要的作用,为我们的生活和工作带来更多的便利和创新。
106 1

热门文章

最新文章

AI助理

你好,我是AI助理

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