【Hello Algorithm】 暴力递归到动态规划 -- 总结

简介: 【Hello Algorithm】 暴力递归到动态规划 -- 总结

动态规划总结

什么样的问题可以动态规划

我们发现过程中有重复调用的问题 我们可以使用动态规划

暴力递归和动态规划的关系

如果一个暴力递归问题 有重复调用的过程 我们就可以把它优化成动态规划

所有的动态规划问题一定可以转化成暴力递归

但是并不是所有的暴力递归都可以转化城动态规划

如何找到某个问题的动态规划方式

  1. 设计暴力递归
  2. 分析有没有重复解
  3. 实现记忆化搜索
  4. 改写动态规划

暴力递归的设计原则

一般来说 我们有几个可变参数 我们就有一张几维表

  1. 我们要设计的可变参数类型一定不要超过整形 如果我们设计的一个可变参数是数组 要改成动态规划是十分困难的
  2. 如果我们违反了原则1 可变参数类型突破到了一维线性结构 那么我们接下来就只能使用一个可变参数 并且要使用记忆化搜索的方式来进行动态规划
  3. 可变参数的个数 能省则省

暴力递归尝试的四种模型

  • 从左往右尝试模型
  • 范围方式模型
  • 样本对应模型
  • 业务限制模型

N皇后问题

本题是leetcode原题

题目连接: N皇后问题

题目描述

按照国际象棋的规则,皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。

n 皇后问题 研究的是如何将 n 个皇后放置在 n×n 的棋盘上,并且使皇后彼此之间不能相互攻击。

给你一个整数 n ,返回所有不同的 n 皇后问题 的解决方案个数.

我们解决n皇后问题的思路如下

我们选择每一行都放一个棋子 这样子我们就能保证最基本的行不冲突 之后我们后面的棋子只需要保证不同列不同斜线就可以

那么现在的问题就变成了我们如何保证不同列不同斜线呢?

我们这里可以选择使用一个数组来记录每一行的列数 之后使用公式判断即可(同斜线公式 行相减的绝对值 = 列相减的绝对值 )

代码表示如下

bool IS_VAILD(vector<int>& cord , int i , int j)
{
  for (int k = 0 ; k < i ; k++)    
  {    
    if (j == cord[k] || abs(cord[k] - j) == abs(i - k))
    {    
      return false;    
    }                                                                                                                                                    
  }    
  return true;    
}    
// 0 ~ n-1    
int process(int i , vector<int>& cord , int n)    
{    
  if (i == n)    
  {    
    return 1;    
  }    
  int ans = 0;    
  for (int j = 0; j < n; j++)    
  {    
    if (IS_VAILD(cord , i , j))    
    {    
      cord[i] = j;    
      ans += process(i+1 , cord , n);    
    }    
  }    
  return ans;
}

这就是一个我们可以写递归但是写不了动态规划的题目

相关文章
|
缓存 Linux
【Hello Algorithm】暴力递归到动态规划(二)
【Hello Algorithm】暴力递归到动态规划(二)
45 0
【Hello Algorithm】暴力递归到动态规划(三)(上)
【Hello Algorithm】暴力递归到动态规划(三)
45 0
|
C语言 容器
【Hello Algorithm】认识一些简单的递归
【Hello Algorithm】认识一些简单的递归
84 0
|
8月前
|
算法 调度 C语言
算法--贪心算法
贪心算法是每次选择当前最优解,期望达到全局最优,适用于有最优子结构的问题。它不回退,与动态规划不同。适用于分数背包问题,但0-1背包问题可能无法保证最优解。常见应用包括找零、最小生成树、单源最短路径和任务调度。贪心算法步骤包括建模、分问题、求局部最优解及整合。尽管简单,但需谨慎评估是否适用,例如0-1背包问题可能需用动态规划求解。
69 1
|
8月前
|
算法
算法系列--动态规划--回文子串系列(下)
算法系列--动态规划--回文子串系列(下)
56 0
|
8月前
|
存储 算法
算法系列--动态规划--回文子串系列(上)
算法系列--动态规划--回文子串系列
60 0
|
8月前
|
算法 计算机视觉
算法系列--动态规划--子序列(1)
算法系列--动态规划--子序列(1)
49 0
|
8月前
|
存储 算法
算法系列--动态规划--子序列(2)(下)
算法系列--动态规划--子序列(2)(下)
55 0
算法学习--动态规划
算法学习--动态规划
|
网络架构
【Hello Algorithm】暴力递归到动态规划(五)
【Hello Algorithm】暴力递归到动态规划(五)
49 0