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

力扣9.7

115.不同的子序列

题目

给你两个字符串 st ,统计并返回在 s 的 子序列 中 t 出现的个数,结果需要对 109 + 7 取模。

数据范围
  • 1 <= s.length, t.length <= 1000
  • st 由英文字母组成
分析

dp[i][j]s的前i个字符构成的子序列中为t的前j个字符的数量,接下来设置边界条件,当t为空时si个字符构成子序列只要空字符串满足,个数为1,即dp[i][0]=1,考虑状态转移

  • 当 s [ i ] ! = t [ j ] , d p [ i + 1 ] [ j + 1 ] = d p [ i ] [ j ] ; 当s[i]!=t[j],dp[i + 1][j + 1] = dp[i][j]; s[i]!=t[j]dp[i+1][j+1]=dp[i][j]
  • 当 s [ i ] = = t [ j ] , d p [ i + 1 ] [ j + 1 ] = d p [ i ] [ j ] + d p [ i ] [ j + 1 ] ; 当s[i]==t[j],dp[i+1][j+1] = dp[i][j] + dp[i][j + 1]; s[i]==t[j]dp[i+1][j+1]=dp[i][j]+dp[i][j+1];
代码
class Solution {
public: const static int N = 1005, mod = 1e9 + 7;int dp[N][N];int numDistinct(string s, string t) {if(s.size() < t.size()) return 0;for(int i = 0; i < s.size(); i ++ ) dp[i][0] = 1;for(int i = 0; i < s.size(); i ++ ) {for(int j = 0; j <= i && j < t.size(); j ++ ) {if(s[i] != t[j]) dp[i + 1][j + 1] = dp[i][j + 1];else dp[i + 1][j + 1] += dp[i][j] + dp[i][j + 1];dp[i + 1][j + 1] %= mod;}} return dp[s.size()][t.size()];}
};

63.不同路径Ⅱ

题目

一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为“Start” )。

机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 “Finish”)。

现在考虑网格中有障碍物。那么从左上角到右下角将会有多少条不同的路径?

网格中的障碍物和空位置分别用 10 来表示。

数据范围
  • m == obstacleGrid.length
  • n == obstacleGrid[i].length
  • 1 <= m, n <= 100
  • obstacleGrid[i][j] 为 0 或 1
分析

dp[i][j]为到那个格子的路径数,考虑状态转移

  • 如果有障碍物, d p [ i ] [ j ] = 0 dp[i][j]=0 dp[i][j]=0
  • 没有障碍物, d p [ i ] [ j ] = d p [ i − 1 ] [ j ] + d p [ i ] [ j − 1 ] dp[i][j]=dp[i-1][j]+dp[i][j-1] dp[i][j]=dp[i1][j]+dp[i][j1]
代码
class Solution {
public:const static int N = 105;int dp[N][N];int uniquePathsWithObstacles(vector<vector<int>>& obstacleGrid) {int n = obstacleGrid.size(), m = obstacleGrid[0].size();for(int i = 0; i < n; i ++ ) {for(int j = 0; j < m; j ++ ) {if(!i && !j && !obstacleGrid[i][j]) {dp[i + 1][j + 1] = 1;continue;}if(obstacleGrid[i][j]) dp[i + 1][j + 1] = 0;else dp[i + 1][j + 1] = dp[i][j + 1] + dp[i + 1][j]; }}return dp[n][m];}
};

746.使用最小花费爬楼梯

题目

给你一个整数数组 cost ,其中cost[i] 是从楼梯第 i 个台阶向上爬需要支付的费用。一旦你支付此费用,即可选择向上爬一个或者两个台阶。

你可以选择从下标为 0 或下标为 1 的台阶开始爬楼梯。

请你计算并返回达到楼梯顶部的最低花费。

数据范围
  • 2 <= cost.length <= 1000
  • 0 <= cost[i] <= 999
分析

dp[i]为到达那一层的最小花费,状态转移:

  • d p [ i ] = m i n ( d p [ i − 1 ] + c o s t [ i − 1 ] , d p [ i − 2 ] + c o s t [ i − 2 ] ) dp[i]=min(dp[i-1]+cost[i - 1],dp[i-2] + cost[i - 2]) dp[i]=min(dp[i1]+cost[i1],dp[i2]+cost[i2])
代码
class Solution {
public:const static int N = 1005;int dp[N];int minCostClimbingStairs(vector<int>& cost) {dp[0] = dp[1] = 0;for(int i = 2; i <= cost.size(); i ++ ) {dp[i] = min(dp[i - 1] + cost[i - 1], dp[i - 2] + cost[i - 2]);}return dp[cost.size()];}
};
http://www.lryc.cn/news/432860.html

相关文章:

  • GPU 带宽功耗优化
  • Linux Centos 7网络配置
  • 第三天旅游线路规划
  • C++第四十七弹---深入理解异常机制:try, catch, throw全面解析
  • go 和 java 技术选型思考
  • 传统CV算法——边缘算子与图像金字塔算法介绍
  • 图像去噪算法性能比较与分析
  • Vision Transformer(ViT)模型原理及PyTorch逐行实现
  • 828华为云征文 | Flexus X实例CPU、内存及磁盘性能实测与分析
  • FreeRTOS学习笔记(六)队列
  • 【Python篇】PyQt5 超详细教程——由入门到精通(中篇一)
  • LinuxQt下的一些坑之一
  • Statement batch
  • PPP 、PPPoE 浅析和配置示例
  • 【Python机器学习】词向量推理——词向量
  • Python 语法糖:让编程更简单(续二)
  • 6 - Shell编程之sed与awk编辑器
  • 什么是XML文件,以及如何打开和转换为其他文件格式
  • 海外直播对网速、带宽、安全的要求
  • UWB定位室外基站
  • 高斯平面直角坐标讲解,以及地理坐标转换高斯平面直角坐标
  • C++入门(06)安装QT并快速测试体验一个简单的C++GUI项目
  • 一篇文章告诉你小程序为什么最近这么火?
  • Qt-常用控件(3)-多元素控件、容器类控件和布局管理器
  • 【系统设计】主动查询与主动推送:如何选择合适的数据传输策略
  • mac 安装brew并配置国内源
  • Temu官方宣导务必将所有的点位材料进行检测-RSL资质检测
  • mysql高级sql
  • Linux CentOS 7.9 安装mysql8
  • 替代 Django 默认 User 模型并使用 `django-mysql` 添加数据库备注20240904