动态规划解题套路框架

本文探讨了动态规划的解题思路,强调了培养框架思维的重要性。介绍了数据结构的基础,如存储方式、种类和基本操作。阐述了如何判断及解决动态规划问题,包括其核心问题、三要素和计算时间复杂度的方法。并通过斐波那契数列的例题,展示了备忘录和dp table在优化暴力解法中的应用,提供了自顶向下和自底向上的解题策略。
摘要由CSDN通过智能技术生成

学习算法不在一招一式,而是培养框架思维。
所谓框架思维,就是套路。不管增删改查,这些代码都是永远无法脱离的结构,你可以把这个结构化作大纲,根据具体问题在框架上添加代码就行了。

一、认识数据结构

数据结构是工具,算法是通过合适的数据结构解决待定为你的方法。

1.1 数据结构存储方式

数据结构的底层存储方式有两种:

  • 数组(顺序存储)
  • 链表(链式存储)

1.2 数据结构种类

  1. 链表
  2. 数组
  3. 散列表
  4. 队列

1.3 数据结构的基本操作

数据结构的操作无非:增删改查

1.4 数据结构遍历 + 访问方式

  • 线性:for/while迭代为代表
  • 非线性:递归为代表

二、如何培养框架思维

  1. 先刷二叉树,因为大部分常考算法本质就是对树的遍历问题。只要涉及递归的问题,基本上都是树的问题。
  2. 从框架看问题,用框架解决问题,不要纠结于细节。
  3. 大量练习。

三、动态规划解题套路框架

3.1 如何判断是否是动态规划问题

动态规划问题的一般形式就是求最值

3.2 动态规划核心问题

动态规划的核心问题就是穷举,要找到最值肯定要把所有值都穷举出来,然后找其中的最值。
当我们遇到求最值的问题时候,一定要先思考如何穷举所有可能结果,这要练成条件反射。

3.3 动态规划三要素

  1. 重叠子问题:动态规划的穷举有点特别,容易对某些项做重复操作,因此我们需要知道两种解决该问题的方法来优化穷举过程“备忘录”和“DP table”,避免不必要的计算。
  2. 最优子结构
  3. 状态转移方程式:其实就是把问题转化为数学方程式,这个是穷举的方案。

3.4 计算时间复杂度

递归的时间复杂度是用子问题个数乘以解决一个子问题需要的时间。

四、备忘录与dp table(优化暴力解法)

备忘录其实就是把我们遍历过的内容保存起来,到下一次遍历,先看看备忘录中有没有该内容,如果有,就把他拿出来直接用。一般用数组或list集合存储。属于自顶向下迭代。

五、动态规划思考框架

动态规划问题的子问题一定是互相独立的

  1. 确定base case(临界状态):也就是迭代终止条件。
  2. 确定“状态”:也就是原问题和子问题中的变量。即不断往base case靠近的变量
  3. 确定“选择”:也就是导致“状态”产生变化的行为

计算机解决问题其实没有任何技巧,他唯一的解决方法就是穷举,因此我们首先思考穷举,进而进行优化,做出“聪明的穷举”

六、典型例题

4.1 斐波那契数列

暴力穷举法

int fib(int n){
   
	if(n == 0) return 0
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值