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

石景山网站制作手机免费发布信息平台

石景山网站制作,手机免费发布信息平台,大型外贸商城网站建设,广州网站制作报价题目: 给定两个字符串 text1 和 text2,返回这两个字符串的最长 公共子序列 的长度。如果不存在 公共子序列 ,返回 0 。 一个字符串的 子序列 是指这样一个新的字符串:它是由原字符串在不改变字符的相对顺序的情况下删除某些字符…

题目:

给定两个字符串 text1 和 text2,返回这两个字符串的最长 公共子序列 的长度。如果不存在 公共子序列 ,返回 0 。

一个字符串的 子序列 是指这样一个新的字符串:它是由原字符串在不改变字符的相对顺序的情况下删除某些字符(也可以不删除任何字符)后组成的新字符串。

  • 例如,"ace" 是 "abcde" 的子序列,但 "aec" 不是 "abcde" 的子序列。

两个字符串的 公共子序列 是这两个字符串所共同拥有的子序列。

看法:

这个题我本人看着在网上没有详细的解释,其实你要搞懂一个问题,整体是让你求最长公共子串的长度比较简单,一直双重遍历,比较 最长子串的长度,但是如果最后要你那个最长公共子串难度会有一个提升,

首先下面第一种方法我用双重遍历去找一下,找到最长公共子串,找到最长公共子串的关键是用map去储存字符串,这样以len为键一下就找到了最长公共子串

代码如下:

#include<iostream>
#include<algorithm>
#include<map>
using namespace std;
int main() {string  s1, s2;s1 = "abcdkkk";s2 = "baabcdadabc";map<int, string>hash;string cnts;int maxlen=0;int len;int i, j;//双层遍历for循环,只动一个字符串for (i = 0; i < s1.length(); i++) {string s3 = "";for (j = i; j < s1.length(); j++) {s3 += s1[j];if (s2.find(s3) != -1) {cnts = s3;len = s3.length();hash[len] = cnts;}}maxlen = max(maxlen, len);}cout << maxlen << " " << hash[maxlen];
}

注意点    如果最大公共子串不止一个,将map改为map<int,vector<string>>,改变 了一下储存方式

代码如下:

#include<iostream>
#include<algorithm>
#include<map>
#include<vector>
using namespace std;
int main() {string  s1, s2;s1 = "abcdkkk";s2 = "baabcdadabc";map<int, vector<string>>hash;string cnts;int maxlen=0;int len;int i, j;//双层遍历for循环,只动一个字符串for (i = 0; i < s1.length(); i++) {string s3 = "";for (j = i; j < s1.length(); j++) {s3 += s1[j];if (s2.find(s3) != -1) {cnts = s3;len = s3.length();hash[len].push_back(cnts);}}maxlen = max(maxlen, len);}cout << maxlen << " " ;for (auto s : hash[maxlen]) {cout << s;}
}

矩阵法:简单的动态规划

1.把两个字符串组成行和列的二维矩阵

2.如果相同则为值取1,不同则取0

3.、通过查找出值为1的最长对角线就能找到最长公共子串

代码如下:

int f(const char* s1, const char* s2)
{int a[N][N];int len1 = strlen(s1);int len2 = strlen(s2);int i,j;memset(a,0,sizeof(int)*N*N);int max = 0;for(i=1; i<=len1; i++){for(j=1; j<=len2; j++){if(s1[i-1]==s2[j-1]) {a[i][j] = a[i-1][j-1]==1? a[i-1][j-1]+1:1; if(a[i][j] > max) max = a[i][j];}}}return max;
}

 

http://www.yidumall.com/news/38792.html

相关文章:

  • 目前做网站数据分析师报考条件
  • 微信平台的微网站怎么做百度在全国有哪些代理商
  • 门户和网站的区别产品软文范例100字
  • 宝格丽网站建设策划案seo同行网站
  • 学校网站建设申请永久不收费免费的聊天软件
  • 网站素材类型地推公司排名
  • 网上服装商城网站代码最好的网站推广软件
  • 网站开发可选择的方案有哪些一级域名好还是二级域名好
  • 国外还有那种做电商的网站apple日本网站
  • 企业网站建设备案都需要什么百度秒收录排名软件
  • 网站建设公司响应式网站模板整站seo教程
  • 口碑最好的it培训机构seo1域名查询
  • 网站内页banner一般做多高百度推广优化是什么?
  • 佛山定制软件开发公司南京百度seo排名
  • wordpress 建多站什么平台可以做引流推广
  • 企业网站维护与销售网络推广公司联系方式
  • 厦门市住房与城乡建设局网站石家庄百度快照优化
  • 网站建设的指导书朝阳区seo
  • soso搜搜网站收录提交入口免费百度广告怎么投放
  • 网站建设及推广人员高级seo课程
  • 男女做羞羞事图片大全动态网站百度有专做优化的没
  • vue.js2.5 pc网站开发公司网站
  • 微信小程序一站式开发南宁seo主管
  • 我的网站搜索不到了市场调研方法有哪些
  • 山西网站建设价格app推广方法
  • 网站使用费用自助建站系统哪个好
  • 单页面网站模板怎么做微信5000人接推广费用
  • 成都网站建设 公司百度一下你就知道百度首页
  • 营销型网站建设方面的书搜狗网站排名软件
  • 做关于什么样的网站好网站推广的目的是什么