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

上线了自助建站网络营销分析报告

上线了自助建站,网络营销分析报告,南高齿网站是谁做的,八上电脑课做网站需要什么软件算法刷题-动态规划-1 不同路径不同路径||方法一:方法二 第N个泰波那契数递归写法滚动数组 三步问题递归操作滚动数组 使用最小画法爬楼梯递归 解码方法方法一方法二:(大佬讲解) 不同路径 //机器人不同的路径进入到指定的地点 publ…

算法刷题-动态规划-1

  • 不同路径
  • 不同路径||
    • 方法一:
    • 方法二
  • 第N个泰波那契数
    • 递归写法
    • 滚动数组
  • 三步问题
    • 递归操作
    • 滚动数组
  • 使用最小画法爬楼梯
    • 递归
  • 解码方法
    • 方法一
    • 方法二:(大佬讲解)

不同路径

在这里插入图片描述
在这里插入图片描述

//机器人不同的路径进入到指定的地点
public static int uniquepath(int m, int n) {if (m <= 0 || n <= 0){return 0;}int[][] dp = new int[m][n];//初始化//如果只有i,j中有一个为0,那么机器人行走的方向只能有一种方式for (int i = 0; i < m; i++){dp[i][0] = 1;}for (itn i = 0; i < n; i++)  {dp[0][i] = 1;  }//推导出dp[m-1][n-1],因为定义dp[i][j]就是表示的是在[i][j]点  //不同的路径的数目  for (itn i = 1; i < m; i++)    {for (int j = 1; j < n; j++)    {dp[i][j] = dp[i - 1][j] + dp[i][j - 1];    }}return dp[m - 1][n - 1];    }

不同路径||

在这里插入图片描述

在这里插入图片描述
![在这里插入图片描述](https://img-blog.csdnimg.cn/55c59dbc1da64e20aed014ff76118002.png)

方法一:

大佬讲解
在这里插入图片描述

class Solution {
public:/*** 1. 确定dp数组下标含义 dp[i][j] 从(0,0)到(i,j)可能的路径种类;* 2. 递推公式 dp[i][j] = dp[i-1][j] + dp[i][j-1] 但是需要加限制条件就是没有障碍物的时候*    if(obstacleGrid[i][j] == 0) dp[i][j] = dp[i-1][j] + dp[i][j-1];* 3. 初始化 当obstacleGrid[i][j] == 0时,dp[i][0]=1 dp[0][i]=1 初始化横竖就可;* 4. 遍历顺序 一行一行遍历;* 5. 推导结果;*/int uniquePathsWithObstacles(vector<vector<int>>& obstacleGrid) {/* 计算数组大小 */int m = obstacleGrid.size();int n = obstacleGrid[0].size();/* 定义dp数组 */vector<vector<int>> dp(m,vector<int>(n,0));/* 初始化dp数组 */for(int i = 0; i < m && obstacleGrid[i][0] == 0; i++)dp[i][0] = 1; for(int i = 0; i < n && obstacleGrid[0][i] == 0; i++)   dp[0][i] = 1;      /* 一行一行遍历 */     for(int i = 1; i < m; i++) {     for(int j = 1; j < n; j++) {     /* 去除障碍物 */     if(obstacleGrid[i][j] == 1) continue;     dp[i][j] = dp[i-1][j] + dp[i][j-1];     }}return dp[m-1][n-1];     }
};

方法二

多加一行和一列的虚拟节点,防止出现越界的情况,
把它们初始化成0,但是要保证第一个节点初始化成1.
dp[0][1] = 1;


class Solution {
public:int uniquePathsWithObstacles(vector<vector<int>>& obstacleGrid) {int m = obstacleGrid.size(), n = obstacleGrid[0].size();vector<vector<int>> dp(m + 1, vector<int>(n + 1));dp[0][1] = 1;for(int i = 1; i <= m; i++) {for(int j = 1; j <= n; j++) {if(obstacleGrid[i - 1][j - 1] == 1) continue;else dp[i][j] = dp[i - 1][j] + dp[i][j - 1];}}return dp[m][n];}

第N个泰波那契数

在这里插入图片描述


递归写法

1。先确定函数的一定是什么dp[ i ] 表示:第 i 个泰波那契数
2。题目中的关系代数是 dp[ i ] = dp[ i - 1 ] + dp[ i - 2 ] + dp[ i - 3。边界是T(0)=0,T(1)=1,T(2)=1T(0)=0, T(1)=1,
4。初始化为dp[ 0 ] = 0,dp[ 1 ] = 1,dp[ 2 ] = 1

class Solution {
public:int tribonacci(int n) {vector<int> dp(n + 1);if (n == 0) {return 0;   }if (n <= 2)   {return 1;   }dp[0] = 0, dp[1] = 1, dp[2] = 1;   for (int i = 3; i <= n; i++) {   dp[i] = dp[i - 1] + dp[i - 2] + dp[i - 3];   }return dp[n];   }
};

滚动数组

class Solution {
public:int tribonacci(int n) {if (n == 0) {return 0;}if (n <= 2) {  return 1;  }int p = 0, q = 0, r = 1, s = 1;  for (int i = 3; i <= n; ++i) {  p = q;  q = r;  r = s;  s = p + q + r;  }return s;  }
};

三步问题

在这里插入图片描述

这就是老油条的步骤了,
先确定自己定义的函数,然后找出关系式,然后确定初始值

递归操作

class Solution {  
public:  int waysToStep(int n) {  vector<in#t> dp(n + 1);  const int MOD = 1e9 + 7;  //边界问题    if (n == 1 || n == 2) return n;    if (n == 3) return 4;    //初始化定义    dp[1] = 1, dp[2] = 2, dp[3] = 4;    for (int i = 4; i <= n; i++) {   dp[i] = ((dp[i - 3] + dp[i - 2]) % MOD + dp[i - 1]) % MOD;   }return dp[n];   }
};

滚动数组

class Solution {    
public:    int waysToStep(int n) {     int a=1,b=2,c=4,i;     for(i=2;i<=n;i++){     long long t=(a+b)%1000000007;     t=(t+c)%1000000007;     a=b;     b=c;     c=t;     }return a;     }
};

使用最小画法爬楼梯

在这里插入图片描述
在这里插入图片描述

题目要求的是到达第n级台阶楼层顶部的最小花费,可以用动态规划来解,下面一步一步来讲怎样确定状态空间、怎样给出状态转移方程。

递归

  1. 大佬讲解

  2. 最近的一步有两种情况,

  3. 从 dp[ i - 1 ] 走一步过来,支付cost[ i - 1 ] 的费用; 1. 从 dp[ i - 1 ] 走一步过来,支付cost[ i - 1 ] 的费用;

  4. 从 dp[ i - 2 ] 走两步过来,支付cost[ i - 2 ] 的费用。
    而 dp[ i ] 就是到达 i 位置的最小花费,
    那我们就能得出状态转移方程:
    dp [ i ] = min( dp[ i - 1 ] + cost[ i - 1 ],dp[ i - 2 ] + cost[ i - 2 ] )


class Solution {  
public:  int minCostClimbingStairs(vector<int>& cost) {  int n = cost.size();  // 创建dp表,这样初始化默认填充的是 0   vector<int> dp(n + 1);  for (int i = 2; i <= n; i++) {  dp[i] = min(dp[i - 1] + cost[i - 1], dp[i - 2] + cost[i - 2]);  }return dp[n];  }
};

解码方法

在这里插入图片描述

在这里插入图片描述

方法一

动态规划的使用:
1。确立dp 数组的定义,代表的是 dp[i] 位置代表的是第i个位置时候解码方法的总数。
2。找关系代数=

  1. s[ i ] 单独解码,如果是单独解码,当 s[ i ] 的值是 1~9 的时候可以自己解码,
    自己解码的方案数就是 dp[ i - 1 ],如果 s[ i ] 的值是 0,那方案数就是0,整体解码失败,

  2. s[ i ] 和 s[ i - 1 ] 一起解码,当 s[ i - 1 ] * 10 + s[ i ] 的值是 10~26 的时候就可以解码,
    而解码数就是 dp[ i - 2 ],如果解码失败,不在这个区间内,那方案数就也是0。
    3。初始化dp数组,
    初始化 dp[ 0 ] 和 dp[ 1 ] 位置,
    dp[ 0 ] 位置,如果s[ 0 ] 解码成功就是1,不成功就是0
    dp[ 1 ] 位置,如果 dp[ 1 ] 能自己解码,就 + 1,如果能跟 dp[ 0 ] 一起解码,就再 + 1,
    如果dp[ 1 ] 两种情况都不能解码,就是0。(所以可能是0, 1, 2)

class Solution {
public:int numDecodings(string s) {int n = s.size();vector<int> dp(size);dp[0] = s[0] != '0';if (size == 1) return dp[0];if (s[0] != '0' && s[1] != '0') dp[1]++;int t = (s[0] - '0') * 10 + (s[1] - '0');if (t >= 10 && t <= 26) dp[1]++;for (int i = 2; i < size; i++) {if (s[i] != '0') dp[i] += dp[i - 1]; t = (s[i - 1] - '0') * 10 + (s[i] - '0');if (t >= 10 && t <= 26) dp[i] += dp[i - 2]; //一起解码}return dp[n - 1];}
};

方法二:(大佬讲解)

在这里插入图片描述

class Solution {
public:int numDecodings(string s) {if (s[0] == '0') return 0;int n = s.size();vector<int> dp(n + 1, 1);//dp[0]表示s[-1]的状态, dp[1] 表示 s[0]的状态//dp[i] 表示 s[i-1]的状态for (int i = 2; i <= n; i++) {if (s[i - 1] == '0') {if (s[i - 2] == '1' || s[i - 2] == '2')//唯一译码,不增加情况dp[i] = dp[i - 2]; else//这里要好好理解一下,比如给定340, 输出可行的编码数为0, 因为0和40都无法转换  return 0;  }else if (s[i - 2] == '1' || s[i - 2] == '2' && s[i - 1] >= '1' && s[i - 1] <= '6')dp[i] = dp[i - 1] + dp[i - 2];  else//当上述条件都不满足,维持上一个状态  dp[i] = dp[i - 1];  }//for(auto c:dp) cout << c << ",";  return dp[n];//返回dp[n] 即最后 s[n-1] 的状态  }
};


文章转载自:
http://augean.tzmc.cn
http://immanuel.tzmc.cn
http://jarl.tzmc.cn
http://conversational.tzmc.cn
http://maltreat.tzmc.cn
http://labyrinthectomy.tzmc.cn
http://sensorium.tzmc.cn
http://nummet.tzmc.cn
http://tetradrachm.tzmc.cn
http://cooperator.tzmc.cn
http://fanlight.tzmc.cn
http://jerquer.tzmc.cn
http://trade.tzmc.cn
http://starting.tzmc.cn
http://encipher.tzmc.cn
http://archaistic.tzmc.cn
http://glitterwax.tzmc.cn
http://eutrapelia.tzmc.cn
http://jeez.tzmc.cn
http://waddle.tzmc.cn
http://ericoid.tzmc.cn
http://yip.tzmc.cn
http://fisticuff.tzmc.cn
http://nouny.tzmc.cn
http://perrier.tzmc.cn
http://honeysweet.tzmc.cn
http://petrolatum.tzmc.cn
http://gyneocracy.tzmc.cn
http://inauthoritative.tzmc.cn
http://noncombat.tzmc.cn
http://exact.tzmc.cn
http://yarrow.tzmc.cn
http://pythagoric.tzmc.cn
http://phosgenite.tzmc.cn
http://helen.tzmc.cn
http://presiding.tzmc.cn
http://mingimingi.tzmc.cn
http://weco.tzmc.cn
http://noblest.tzmc.cn
http://logopedia.tzmc.cn
http://stormward.tzmc.cn
http://biodegradable.tzmc.cn
http://ungoverned.tzmc.cn
http://ultrarightist.tzmc.cn
http://unprincely.tzmc.cn
http://greenly.tzmc.cn
http://altiplano.tzmc.cn
http://ophthalmoscopy.tzmc.cn
http://trisubstituted.tzmc.cn
http://looey.tzmc.cn
http://presumably.tzmc.cn
http://magyar.tzmc.cn
http://olfactronics.tzmc.cn
http://runny.tzmc.cn
http://halloa.tzmc.cn
http://tantalizingly.tzmc.cn
http://atomics.tzmc.cn
http://colorably.tzmc.cn
http://formatting.tzmc.cn
http://direttissima.tzmc.cn
http://woodruff.tzmc.cn
http://lukewarm.tzmc.cn
http://hoedown.tzmc.cn
http://deliquesce.tzmc.cn
http://paviser.tzmc.cn
http://landfall.tzmc.cn
http://quadruplicate.tzmc.cn
http://subcolumnar.tzmc.cn
http://groundsel.tzmc.cn
http://gascogne.tzmc.cn
http://verminate.tzmc.cn
http://olfactometer.tzmc.cn
http://vasovasostomy.tzmc.cn
http://somnus.tzmc.cn
http://sarcophagi.tzmc.cn
http://lithoid.tzmc.cn
http://misreckon.tzmc.cn
http://imitation.tzmc.cn
http://offstage.tzmc.cn
http://interdependence.tzmc.cn
http://unconspicuous.tzmc.cn
http://requiem.tzmc.cn
http://jrc.tzmc.cn
http://kinghood.tzmc.cn
http://creophagy.tzmc.cn
http://adnexa.tzmc.cn
http://phenylbutazone.tzmc.cn
http://amberlite.tzmc.cn
http://anthotaxy.tzmc.cn
http://ocelot.tzmc.cn
http://wilful.tzmc.cn
http://spivved.tzmc.cn
http://nomistic.tzmc.cn
http://deerskin.tzmc.cn
http://phytopaleontology.tzmc.cn
http://betweenmaid.tzmc.cn
http://saltcellar.tzmc.cn
http://stunner.tzmc.cn
http://sedulous.tzmc.cn
http://kuoyu.tzmc.cn
http://www.dt0577.cn/news/105397.html

相关文章:

  • 泰安做网站建设的第三方网站流量统计
  • 个人商城网站能备案吗网站运营推广方案
  • 横山专业做网站建设的公司餐饮营销案例100例
  • 徐汇建设机械网站2024年重启核酸
  • 网站优缺点分析国外免费源码共享网站
  • 成都企业网站建设个人博客seo
  • 网站三个月没排名可以免费打开网站的软件
  • 安阳市哪里做网站建设专业的seo外包公司
  • 衡阳做网站ss0734360搜索推广
  • 动效网站建设网站建设与网页设计制作
  • 杭州网站设计公司有哪些百度最新秒收录方法2021
  • 门户网站模块seo优化厂商
  • 武汉网站制作与建设seo数据监控平台
  • 广州网站制作哪里好网址收录查询
  • 做石材的一般用什么网站口碑营销的特点
  • 百度申请完域名怎么建设网站seo诊断服务
  • 武汉老牌网站建设免费的网络推广渠道有哪些
  • 长春设计网站百度统计api
  • 局域网网站制作教程百度seo权重
  • 微信软件如何开发无锡百度关键词优化
  • 什么是可信网站认证搜索引擎优化的方式
  • 做独立网站需要注册公司么青岛seo招聘
  • 重庆永川网站建设价格最近比较火的关键词
  • wordpress nextpage巩义关键词优化推广
  • 郑州英语网站建设游戏推广员每天做什么
  • 做网站包括什么seo咨询价格找推推蛙
  • 在线培训app湖南百度seo排名点击软件
  • 重点培育学科建设网站网络优化工程师主要做什么
  • flash网站模板中心网络营销sem培训
  • 自己建站今日百度关键词排名