当前位置: 首页 > news >正文

h5哪个网站可以做线上推广方式都有哪些

h5哪个网站可以做,线上推广方式都有哪些,做海报的网站什么编辑,网站搭建后台Dynamic Programming 动态规划(Dynamic Programming, DP) 是一种算法设计技巧,通常用来解决具有重叠子问题和最优子结构性质的问题。它通过将问题分解为更小的子问题,逐步解决这些子问题并将结果存储起来,以避免重复计…

Dynamic Programming

动态规划(Dynamic Programming, DP) 是一种算法设计技巧,通常用来解决具有重叠子问题和最优子结构性质的问题。它通过将问题分解为更小的子问题,逐步解决这些子问题并将结果存储起来,以避免重复计算,从而提高效率。


1. 特点

1.1 重叠子问题

在许多递归问题中,计算过程中会多次遇到相同的子问题。如果我们每次遇到这些子问题时都重新计算,会导致大量的重复计算和效率低下。重叠子问题的思想是通过将子问题的结果存储起来,避免重复计算,从而提高效率。

举例

斐波那契数列

递归关系式

T ( n ) = T ( n − 1 ) + T ( n − 2 ) T(n)=T(n-1)+T(n-2) T(n)=T(n1)+T(n2)

计算T(3)

T ( 3 ) = T ( 2 ) + T ( 1 ) = T ( 1 ) + T ( 0 ) + T ( 1 ) \begin{aligned} T(3) &= T(2) + T(1) \\ &= T(1) + T(0) + T(1) \end{aligned} T(3)=T(2)+T(1)=T(1)+T(0)+T(1)

这里我们可以看见T(1)被多次计算

这个多次计算的T(1)便被称为重复子问题

如果我们用递归来解决这个问题

int fin(int n){if(n==1)return 1;if(n==0)return 0;return fin(n-1)+fin(n-2);
}

画出递归树

在这里插入图片描述

我们可以看到有多次递归调用都是重复的,即出现了重复子问题。

1.2 记忆化存储

继续探究斐波那契问题

我们之前发现使用递归解决问题时出现了多次递归调用是重复的
在这里插入图片描述

我们可以将这些重复子问题的结果储存起来,这样下一次需要解决这个子问题的时候,只需要访问之前的结果就可以了。

模拟实现

int fin(int n){std::vector<int>Fin(n+1);Fin[0]=0;Fin[1]=1;for(int i=2;i<=n;i++){Fin[i]=Fin[i-1]+Fin[i-2];}return Fin[n];
}

可以看出来我们是从最小子问题来逐渐递推至最后的答案,这也被称为自底而上的算法

1.4 状态转移方程

我们来看斐波那契数列的递推关系式

T ( n ) = T ( n − 1 ) + T ( n − 2 ) T(n)=T(n-1)+T(n-2) T(n)=T(n1)+T(n2)

这里我们可以看出,如果我们想得到第n项的答案,我们就要知道第n-1项和第n-2项的答案

T ( n ) ← 这个第 n 项的答案,就定义为一个状态 T(n) \gets 这个第n项的答案,就定义为一个状态 T(n)这个第n项的答案,就定义为一个状态

状态转移方程表示的就是某一个状态和其他状态之间的关系

T ( n ) = T ( n − 1 ) + T ( n − 2 ) T(n)=T(n-1)+T(n-2) T(n)=T(n1)+T(n2)

这个方程就表示第n个状态是由第n-1个状态和第n-2个状态决定

1.5 最优子结构

还是看斐波那契数列

我们如果要求出第n个状态的状态值,那么我们一定是使用第n-1个状态和第n-2个状态的值来计算的。

由于我们的状态转移方程是确定的,这里求出的一定是最优解。

给出定义

如果一个问题的最优解包含了其子问题的最优解,则称这个问题具有最优子结构性质。


2. 用动态规划来设计算法的步骤

2.1 理解问题并确定子问题

首先,理解斐波那契数列的问题。斐波那契数列定义如下:

F ( n ) = F ( n − 1 ) + F ( n − 2 ) F(n) = F(n-1) + F(n-2) F(n)=F(n1)+F(n2)

其初始条件为:
F ( 0 ) = 0 F(0) = 0 F(0)=0
F ( 1 ) = 1 F(1) = 1 F(1)=1

这个问题可以分解为子问题,即计算第 ( n ) 项的值依赖于第 ( n-1 ) 项和第 ( n-2 ) 项的值。

2.2 定义状态

定义状态 ( dp[i] ) 表示斐波那契数列第 ( i ) 项的值。

d p [ i ] ← 斐波那契数列第 i 项的值 dp[i] \gets 斐波那契数列第 i 项的值 dp[i]斐波那契数列第i项的值

2.3 确定状态转移方程

状态转移方程基于斐波那契数列的递归定义,可以写作:
d p [ i ] = d p [ i − 1 ] + d p [ i − 2 ] dp[i] = dp[i-1] + dp[i-2] dp[i]=dp[i1]+dp[i2]

2.4 确定初始状态和边界

根据斐波那契数列的初始条件,初始化状态:

d p [ 0 ] = 0 dp[0] = 0 dp[0]=0
d p [ 1 ] = 1 dp[1] = 1 dp[1]=1

2.5 利用状态转移方程计算状态值

使用状态转移方程从初始状态开始逐步计算到目标状态值。

#include <vector>int fib(int n) {if (n <= 1) return n;std::vector<int> dp(n + 1);dp[0] = 0;dp[1] = 1;for (int i = 2; i <= n; ++i) {dp[i] = dp[i - 1] + dp[i - 2];}return dp[n];
}
http://www.yidumall.com/news/10665.html

相关文章:

  • 网站策划书我与音乐搞一个公司网站得多少钱
  • 做网站建设优化的公司排名个人做外贸怎样起步
  • 小公司做网站推广好不好十大搜索引擎
  • 网站footer怎么做西安疫情最新数据消息中高风险地区
  • 青岛网站设计公司价格自己开发网站
  • 所有的网站都要用htmlu做吗湘潭网站设计外包公司
  • 海报设计制作平台重庆seo排名优化费用
  • 山西两学一做登录网站付费内容网站
  • 网站banner分辨率站长工具seo综合查询降级
  • web网站设计案例百度seoo优化软件
  • 网站防注入制作网站的基本流程
  • 四川网站建设电话买卖链接网
  • 哈尔滨网站推广关键词优化公司排名榜
  • vip影视网站如何做app免费建网页
  • 如何学习制作网站交换友链是什么意思
  • 零基础学做网站教程环球贸易网
  • 怎么做web网站百度登录个人中心官网
  • 凡科邮箱登录seo优化推广
  • 青岛茶叶网站建设网站怎样优化seo
  • 公司内部网站维护免费的外贸b2b网站
  • 企业网站源码怎么获取杭州seo关键词优化公司
  • wordpress怎么配置七牛cdn加速windows优化大师下载安装
  • 2018威胁网站检测平台建设建网站需要多少钱和什么条件
  • wordpress移动排版网站优化的方法与技巧
  • 用bootstrap做的外国网站开鲁网站seo站长工具
  • 建新网站开发流程图seo教程seo优化
  • 网站建设石家庄快优最佳搜索引擎
  • 网站建设以及运营方面网络优化的内容包括哪些
  • 保险做的好的网站有哪些内容网站维护的主要内容
  • 开封做网站公司汉狮品牌营销策略四种类型