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

网站制作 台州排名公式

网站制作 台州,排名公式,seo关键词排名工具,知名设计公司logo115.不同的子序列 题目 dp[i][j]表示的是在以是s[j]为结尾的字符串中最多可以找到几种组成以t[i]为结尾的字符串的方式。 如果s[i]t[j], 1.利用第i个和第j个匹配,在j-1中寻找i-1. 2.不适用这两个进行匹配,在j-1中寻找i 如果s[i]!…

115.不同的子序列

题目
dp[i][j]表示的是在以是s[j]为结尾的字符串中最多可以找到几种组成以t[i]为结尾的字符串的方式。
如果s[i]==t[j],
1.利用第i个和第j个匹配,在j-1中寻找i-1.
2.不适用这两个进行匹配,在j-1中寻找i
如果s[i]!=t[j]
则只能在j-1中寻找i

 for(int i=1;i<m+1;i++){for(int j=i;j<n+1;j++){if(t[i-1]==s[j-1]){dp[i][j]=(dp[i-1][j-1]+dp[i][j-1])%(1000000007);}elsedp[i][j]=dp[i][j-1];}}

完整代码:

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

583. 两个字符串的删除操作

方法一

找出两个字符串的最长公共子序列,然后用两个字符串的长度之和减去2*dp[m][n]

方法二

dp[i][j]代表以word1[i]和word2[j]为结尾的字符串删成相同的字符串需要的最小步数
if(word1[i]==word2[j]){
dp[i][j]=dp[i-1][j-1];
}
else{
dp[i][j]=min(dp[i-1][j]+1,dp[i][j-1]+1);
//分别删除第i个和第j个后剩余字符串的最小步数,再加上前面删除的一个步数。
}

class Solution {
public:int minDistance(string word1, string word2) {int m=word1.size();int n=word2.size();vector<vector<int>> dp(m+1,vector<int>(n+1,0));for(int i=1;i<m+1;i++){dp[i][0]=i;}for(int j=1;j<n+1;j++)dp[0][j]=j;for(int i=1;i<m+1;i++){for(int j=1;j<n+1;j++){if(word1[i-1]==word2[j-1]){dp[i][j]=dp[i-1][j-1];}elsedp[i][j]=min(dp[i-1][j]+1,dp[i][j-1]+1);//分别删除第i个和第j个后剩余字符串的最小步数,再加上前面删除的一个步数。}}return dp[m][n];}
};

72. 编辑距离

如果word1[i]和word2[j]不相同,有三种方式:
1.修改第i个使他与j相同,要dp[i-1][j-1]+1步
2.删除第i个,要dp[i-1][j]+1
3.删除第j个,要dp[i][j-1]+1

插入一个和另一个相等的字符和删除另一个的步数一样,所以可以只用讨论删除的。

if(word1[i-1]!=word2[j-1]){	dp[i][j]=min(dp[i-1][j-1]+1,min(dp[i-1][j]+1,dp[i][j-1]+1;
}
elsedp[i][j]=dp[i-1][j-1];

注意:是i-1和j-1,因为i的长度比m多一个。

完整代码:

class Solution {
public:int minDistance(string word1, string word2) {int m=word1.size();int n=word2.size();vector<vector<int>> dp(m+1,vector<int>(n+1,0));for(int i=1;i<m+1;i++)dp[i][0]=i;for(int j=1;j<n+1;j++)dp[0][j]=j;for(int i=1;i<m+1;i++){for(int j=1;j<n+1;j++){if(word1[i-1]!=word2[j-1]){	dp[i][j]=min(dp[i-1][j-1]+1,min(dp[i-1][j]+1,dp[i][j-1]+1));}elsedp[i][j]=dp[i-1][j-1];}}return dp[m][n];}
};
http://www.dt0577.cn/news/37957.html

相关文章:

  • 网页转图片成都百度网站排名优化
  • 武汉做网站需要多少钱泉州seo按天计费
  • 哪个网站上网好百度信息流投放方式有哪些
  • 求网站建设的视频河北seo关键词排名优化
  • 做网站有哪些项目邯郸百度推广公司
  • 美食网站怎么做广州引流推广公司
  • 顺德网站制作案例效果seo如何优化的
  • 免费请美女做爰网站自媒体135免费版下载
  • 电子邮箱怎么申请注册网络公司优化关键词
  • 面包屑 网站竞价账户托管的公司有哪些
  • 关于网站建设的图片百度小说排行榜
  • 做网站现在什么最赚钱吗单页站好做seo吗
  • 厦门建网站平台站长工具seo优化建议
  • 网站建设进度控制青岛关键词网站排名
  • wordpress网页制作seo优化效果怎么样
  • centos wordpress 500seo的优化策略有哪些
  • 安徽省建设工程测试研究院网站手机优化大师官方免费下载
  • 韩国免费行情网站的推荐理由跨境电商关键词工具
  • 重庆市城市建设综合开发办网站客服外包
  • 如何获取网站根目录链接站长统计幸福宝2022年排行榜
  • 网站解析需要什么安卓优化大师app下载
  • 查询网站建设怎么创建一个网站
  • 网站建设质量要求优化手机流畅度的软件
  • 做网站数据库表设计郑州优化网站关键词
  • 网站托管公司哪家好网络营销项目策划方案
  • 做视频网站怎么盈利模式重庆seo整站优化系统
  • html做网站经验技巧怎么搭建自己的网站
  • 电脑怎么做网站百度软文推广公司
  • 南充网站开发搜外友链
  • 西部数码网站管理助手 数据库bt兔子磁力搜索