递归思想,动态规划思想学习

本文深入探讨了递归算法的应用,解析了递归在解决特定问题上的优势,如Fibonacci数列、Hanoi塔及树结构操作。通过具体实例,如LeetCode题目解答,展现了递归与动态规划的魅力。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

递归思想

程序调用自身的编程技巧称为递归( recursion)。
递归算法一般用于解决三类问题:
(1)数据的定义是按递归定义的。(Fibonacci函数)
(2)问题解法按递归算法实现。
这类问题虽则本身没有明显的递归结构,但用递归求解比迭代求解更简单,如Hanoi问题。
(3)数据的结构形式是按递归定义的。
如二叉树、广义表等,由于结构本身固有的递归特性,则它们的操作可递归地描述。

def fib(n):	
	'''
	fibonacci问题
	'''
    if n < 2:
        return 1
    else:
        return fib(n-1) + fib(n-2)
print([fib(n) for n in range(5)])

leetcode206

class Solution:
    def reverseList(self, head, prev = None):
        """
        :type head: ListNode
        :rtype: ListNode
        """

        # 尾递归
        if not head:
            return prev

        curr, head.next = head.next, prev  
        return self.reverseList(curr, head)

动态规划

入门篇教你彻底学会动态规划

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值