Python递归树结构,回溯法深度优先、广度优先详解,代码实现

简介: Python递归树结构,回溯法深度优先、广度优先详解,代码实现

Python实现,递归算法,深度优先、广度优先


其实递归说白了就是循环本身函数,只不过下次循环的输入值是上次循环的结果值。关于递归算法,我经常把它用在搜索、计算中。我们来看一个简单的例子:


计算Demo


'要实现1,3,7,15,31''有如下数列,请问第7位是多少 --> 127 '
#普通写法
def simple(time):
    '''如上可以看出规则为 1 * 2 + 1 ''' '''此时如果硬写代码会比较繁琐,'''
    time -= 1
    for i in range(time):
        if i == 0:
            factor = (0 * 2 + 1)
        val = factor * 2 + 1
        factor = val
    return factor
print(f'硬写:{simple(7)}')
#递归算法
def loop(time, n=1, factor=0):
    val = factor * 2 + 1
    if n == time:
        return val
    return loop(time, n + 1, val)
print(f'递归:{loop(7)}')

1684141674586.jpg


从上述代码中可以看到,用递归计算真的是非常方便了。虽然是个很简单的例子,但是也可以看出来递归算法节省了很多代码并且逻辑也是非常清晰。对于我们Python来讲,简洁、明了的代码才是最好的代码,所以力荐!!!


搜索Demo(深度优先、广度优先)


关于递归算法, 上面的例子以及充分展示了,不再多说。下面讲一下在递归中经常用到的搜索方法。

深度优先:

广度优先:

'''搜索'''
lis= [('文件1','文件5','文件8','文件21'),
      ('文件12','文件4','文件2','文件34'),
      ('文件18','文件10','文件9','文件16')]
'''这里以搜索文件举例,如上有三层:深度优先搜索指的是由 0.0->0.1->0.2 -> 1.0->1.1->1.2
                           #广度优先搜索指的是由 0.0->1.0->2.0 -> 0.1->1.1->2.1'''


无论都是通过遍历而来,只不过遍历的时候给出了方向而已。

看一个简单的例子

'''搜索'''
lis = [('文件1', '文件5', '文件8', '文件21'),
       ('文件12', '文件4', '文件2', '文件34'),
       ('文件18', '文件10', '文件9', '文件16')]
# 假如我们要找'文件2'
# 深度优先:    文件1->文件5
frequency = 0
for tup_index in range(len(lis)):  # 得到lis总长度,通过索引遍历
    for k in range(len(lis[tup_index])):
        frequency += 1
        if lis[tup_index][k] == '文件2':
            print(f'找到了,位置是{tup_index, k},共查找{frequency}次')
# 广度优先:   文件1->文件12
import numpy as np
frequency = 0
lis = np.transpose(lis)  # 转置一下
'''
[['文件1' '文件12' '文件18']
 ['文件5' '文件4' '文件10']
 ['文件8' '文件2' '文件9']]'''
for tup_index in range(len(lis)):  # 得到lis总长度,通过索引遍历
    for k in range(len(lis[tup_index])):
        frequency += 1
        if lis[tup_index][k] == '文件2':
            '''因为我们转置了,所以得出来的位置 2,1 需要对调为 1,2'''
            print(f'找到了,位置是{k, tup_index},共查找{frequency}次')

1684141732412.jpg


这两种方法视实际情况而用,无所谓好坏。也可以结合使用。如下:

[('文件1','文件5','文件8','文件21'),
      ('文件12','文件4','文件2','文件34'),
      ('文件18','文件10','文件9','文件16')]
问:请找到'文件2'!
已知: '文件2' 在 '文件12' 之后且'文件12'在第一层。
答:可以先利用广度优先找到'文件12',需2步,找到之后再用深度优先往下找,需2步,总共4步找到 '文件2'。


好啦,到此递归算法的使用也就差不多啦。

相关文章
|
1天前
|
缓存 开发者 Python
探索Python中的装饰器:简化和增强你的代码
【10月更文挑战第32天】 在编程的世界中,简洁和效率是永恒的追求。Python提供了一种强大工具——装饰器,它允许我们以声明式的方式修改函数的行为。本文将深入探讨装饰器的概念、用法及其在实际应用中的优势。通过实际代码示例,我们不仅理解装饰器的工作方式,还能学会如何自定义装饰器来满足特定需求。无论你是初学者还是有经验的开发者,这篇文章都将为你揭示装饰器的神秘面纱,并展示如何利用它们简化和增强你的代码库。
|
2天前
|
机器学习/深度学习 自然语言处理 API
如何使用阿里云的语音合成服务(TTS)将文本转换为语音?本文详细介绍了从注册账号、获取密钥到编写Python代码调用TTS服务的全过程
如何使用阿里云的语音合成服务(TTS)将文本转换为语音?本文详细介绍了从注册账号、获取密钥到编写Python代码调用TTS服务的全过程。通过简单的代码示例,展示如何将文本转换为自然流畅的语音,适用于有声阅读、智能客服等场景。
18 3
|
4天前
|
设计模式 缓存 测试技术
Python中的装饰器:功能增强与代码复用的艺术####
本文将深入探讨Python中装饰器的概念、用途及实现方式,通过实例演示其如何为函数或方法添加新功能而不影响原有代码结构,从而提升代码的可读性和可维护性。我们将从基础定义出发,逐步深入到高级应用,揭示装饰器在提高代码复用性方面的强大能力。 ####
|
2天前
|
算法 IDE API
Python编码规范与代码可读性提升策略####
本文探讨了Python编码规范的重要性,并深入分析了如何通过遵循PEP 8等标准来提高代码的可读性和可维护性。文章首先概述了Python编码规范的基本要求,包括命名约定、缩进风格、注释使用等,接着详细阐述了这些规范如何影响代码的理解和维护。此外,文章还提供了一些实用的技巧和建议,帮助开发者在日常开发中更好地应用这些规范,从而编写出更加清晰、简洁且易于理解的Python代码。 ####
|
5天前
|
缓存 测试技术 数据安全/隐私保护
探索Python中的装饰器:简化代码,增强功能
【10月更文挑战第29天】本文通过深入浅出的方式,探讨了Python装饰器的概念、使用场景和实现方法。文章不仅介绍了装饰器的基本知识,还通过实例展示了如何利用装饰器优化代码结构,提高代码的可读性和重用性。适合初学者和有一定经验的开发者阅读,旨在帮助读者更好地理解和应用装饰器,提升编程效率。
|
12天前
|
开发者 Python
探索Python中的装饰器:简化代码,增强功能
【10月更文挑战第22天】在Python的世界里,装饰器是一个强大的工具,它能够让我们以简洁的方式修改函数的行为,增加额外的功能而不需要重写原有代码。本文将带你了解装饰器的基本概念,并通过实例展示如何一步步构建自己的装饰器,从而让你的代码更加高效、易于维护。
|
9天前
|
算法 测试技术 开发者
在Python开发中,性能优化和代码审查至关重要。性能优化通过改进代码结构和算法提高程序运行速度,减少资源消耗
在Python开发中,性能优化和代码审查至关重要。性能优化通过改进代码结构和算法提高程序运行速度,减少资源消耗;代码审查通过检查源代码发现潜在问题,提高代码质量和团队协作效率。本文介绍了一些实用的技巧和工具,帮助开发者提升开发效率。
12 3
|
13天前
|
开发框架 Python
探索Python中的装饰器:简化代码,增强功能
【10月更文挑战第20天】在编程的海洋中,简洁与强大是航行的双桨。Python的装饰器,这一高级特性,恰似海风助力,让代码更优雅、功能更强大。本文将带你领略装饰器的奥秘,从基础概念到实际应用,一步步深入其内涵与意义。
|
11天前
|
机器学习/深度学习 缓存 数据挖掘
Python性能优化:提升你的代码效率
【10月更文挑战第22天】 Python性能优化:提升你的代码效率
10 1
|
14天前
|
机器人 Shell Linux
【Azure Bot Service】部署Python ChatBot代码到App Service中
本文介绍了使用Python编写的ChatBot在部署到Azure App Service时遇到的问题及解决方案。主要问题是应用启动失败,错误信息为“Failed to find attribute 'app' in 'app'”。解决步骤包括:1) 修改`app.py`文件,添加`init_func`函数;2) 配置`config.py`,添加与Azure Bot Service认证相关的配置项;3) 设置App Service的启动命令为`python3 -m aiohttp.web -H 0.0.0.0 -P 8000 app:init_func`。