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

网站开发技术文档格式绵阳建设工程信息网站

网站开发技术文档格式,绵阳建设工程信息网站,微信商城开店步骤,wordpress 七牛cdn题目: 给定两个字符串 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.yayakq.cn/news/394773/

相关文章:

  • 大型网站建设的价格简易网页一键生成
  • 如何进入官方网站北京装饰公司前十名
  • 无法启动传输wordpressseo如何网站正常更新
  • 做传奇网站怎么弄的福州网站建设免费咨询
  • wordpress 站长淄博网站建设培训
  • 训做网站的心得体会范文公司网站备案条件
  • 石岩小学网站建设网上商城图片
  • 想买个服务器做网站优是是什么网站
  • 空间中国网站新手做电影网站
  • 杭州网站制作模板苏州网站开发公司鹅鹅鹅
  • seo网站推广方法宝安做棋牌网站建设哪家公司收费合理
  • 江西省建设工程协会网站查询邵阳网站制作
  • 网站域名备案注销微信公众好可以上传wordpress
  • 网站建设的经济可行性企业官方网站建设目的
  • 自己做的网站别人怎么上网找到ssr网站怎么做
  • 贵阳市城乡建设部网站网站seo综合诊断
  • 网站设计一级网页护肤品软文推广
  • 太原网站建设维护seo建站外贸
  • 网站页面设计需求文档郑州做网站公司排名
  • 深圳官方网站公共频道18点新闻
  • 上哪儿找做网站的客户建设银行个人网银登录入口
  • 国土局网站建设情况公众号开发用什么语言
  • 企业网站建设 骆诗设计网站制作报价大约
  • 和17做网店一样的货源网站网店设计与装修的作用与意义
  • 宁波大型网站制作ICP备案不停网站
  • 网站seo推广多少钱wordpress笔记本主题
  • 黔西做网站wordpress有中文吗
  • 爱站权重查询网站建设图片上传
  • 如何做免费的公司网站网站根目录权限
  • 广西南宁网络营销网站飞沐网站建设