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

建设一个网站需要什么安全设备达内学网站开发培训课程

建设一个网站需要什么安全设备,达内学网站开发培训课程,百度广告买下的订单在哪里找,加快公司网站建设给你两个字符串 s 和 t ,统计并返回在 s 的 子序列 中 t 出现的个数,结果需要对 10^9 7 取模。 示例 1: 输入:s “rabbbit”, t “rabbit” 输出:3 解释: 如下所示, 有 3 种可以从 s 中得到 “rabbit”…

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

示例 1:
输入:s = “rabbbit”, t = “rabbit”
输出:3
解释:
如下所示, 有 3 种可以从 s 中得到 “rabbit” 的方案。
在这里插入图片描述

示例 2:
输入:s = “babgbag”, t = “bag”
输出:5
解释:
如下所示, 有 5 种可以从 s 中得到 “bag” 的方案。
在这里插入图片描述

提示:
1 <= s.length, t.length <= 1000
s 和 t 由英文字母组成

动态规划

class Solution {
public:int numDistinct(string s, string t) {int MOD = 1e9 + 7;int m = s.size(), n = t.size();if(n > m){return 0;}vector<vector<int>> f(m+1, vector<int>(n+1));for(int i = 0; i <= m; i++){f[i][0] = 1;}for(int i = 1; i <= m; i++){for(int j = 1; j <= min(i, n) ; j++){if(s[i-1] == t[j-1]){f[i][j] = (f[i-1][j-1] + f[i-1][j]) % MOD;}else{f[i][j] = f[i-1][j] % MOD;}}}return f[m][n];}
};

时间复杂度:O(mn),其中 m 和 n 分别是字符串 s 和 t 的长度。二维数组 dp 有 m+1 行和 n+1 列,需要对 dp 中的每个元素进行计算。

空间复杂度:O(mn),其中 m 和 n 分别是字符串 s 和 t 的长度。创建了 m+1 行 n+1 列的二维数组 dp。

这个题运用了动态规划的思想,我们首先定义一个二维动态数组f[i][j],设 f[i][j] 表示字符串 s 的前 i 个字符中,子序列中 t 的前 j 个字符出现的次数。

如果 s[i - 1] == t[j - 1],那么 f[i][j] 既可以选择使用 s[i - 1] 来匹配 t[j - 1],也可以不使用 s[i - 1]。此时状态转移方程为:

f[i][j] = (f[i-1][j-1] + f[i-1][j]) % MOD;

如果 s[i - 1] != t[j - 1],则无法匹配 t[j - 1],因此只能继承之前的状态:

f[i][j] = f[i - 1][j]

最后返回f[m][n]。


优化:滚动数组

class Solution {
public:int numDistinct(string s, string t) {int MOD = 1e9 + 7;int m = s.size(), n = t.size();if(n > m){return 0;}vector<int> f(n+1);f[0] = 1;for(int i = 1; i <= m; i++){for(int j = min(i, n); j >= 1 ; j--){if(s[i-1] == t[j-1]){f[j] = (f[j-1] + f[j]) % MOD;}}}return f[n];}
};

我们可以观察到f[i][j] = (f[i-1][j-1] + f[i-1][j]) % MOD;中,f[I][j]上一行的前一个字符转换而来,还有由同一行的前一个字符转换而来。所以我们可以省去行的空间,只定义一个包含列的一维数组f[n],我们在循环中让j倒序,我们就有f[j-1]等同于f[i-1][j-1],f[j]等同于f[i-1][j]。并且在f[i][j] = f[i-1][j] % MOD;中,f[i-1][j]会转换成f[j] = f[j],所以我们不需要列出这种情况。

http://www.yayakq.cn/news/341994/

相关文章:

  • 建网站的基本流程怎么做招标公司网站
  • 杏坛网站建设内蒙古两学一做网站
  • 模板建站常规流程石家庄建设项目公示网
  • 碧海蓝天网站wordpress能改什么
  • 如何编写网站建设wordpress修改logo
  • 网站开发用到的编程做网站360业务
  • 网站数据库分离怎么做做电工的有接单的网站吗
  • 商业网站的建设与制作松岗专业做网站公司
  • 网站建设应计入哪个会计科目为什么大网站的百度快照更新速度慢还排第一
  • 建设项目验收在哪个网站公示凯里市经济开发区建设局网站
  • cp网站开发搭建什么网站开发外贸客户
  • 在eclipse中做网站开发成都网站制作公司
  • 做钢丝绳外贸的网站电子商务公司怎么样
  • 网站建设实训总结报告做网站找投资人
  • 网站优化排名易下拉软件做网站前景怎么样
  • ai做的网站怎么切图wordpress改地址
  • 装饰网站建设套餐报价企业的漏沟设计公司
  • 重庆网站建设公司是什么意思IT男网站建设
  • 自做跨境电商网站收款网站设计登录界面怎么做
  • 网站后台自动退出wordpress3.4.2漏洞
  • 网站建设十胜石萍乡企业做网站
  • 叫别人做网站后怎么更改密码网站内页设计
  • 前端开发 网站建设企业门户定制网站建设公司
  • 怎么投诉网站制作公司百度推广账户优化
  • 官方网站下载安装qq常州网络科技有限公司
  • 网站怎么做中英文交互做网站需要什么学历
  • 动易网站论坛建设项目验收在哪个网站公示
  • 帝国cms如何做微网站湖南网站建设哪里好
  • 怎么找网站建设微信公众号怎么用
  • 学校网站建设钉钉网站设计论文总结与展望