`

南阳理工OJ 36 最长公共子序列

 
阅读更多

连接: http://acm.nyist.net/JudgeOnline/problem.php?pid=36

 

最长公共子序列

时间限制:3000 ms  |  内存限制:65535 KB
难度:3
 
描述
咱们就不拐弯抹角了,如题,需要你做的就是写一个程序,得出最长公共子序列。
tip:最长公共子序列也称作最长公共子串(不要求连续),英文缩写为LCS(Longest Common Subsequence)。其定义是,一个序列 S ,如果分别是两个或多个已知序列的子序列,且是所有符合此条件序列中最长的,则 S 称为已知序列的最长公共子序列。
 
输入
第一行给出一个整数N(0<N<100)表示待测数据组数
接下来每组数据两行,分别为待测的两组字符串。每个字符串长度不大于1000.
输出
每组测试数据输出一个整数,表示最长公共子序列长度。每组结果占一行。
样例输入
2
asdf
adfsd
123abc
abc123abc
样例输出
3
6

 

 

动态规划:p[i][j]表示第一个串的第i个和第二个串的j比较时的最优解

如果  str1[i]==str2[j]   则p[i][j]=p[i-1][j-1]+1;

否则  p[i][j]=max( p[i-1][j]  ,  p[i][j-1] );

然后  p[len1][len2]就是要求的结果啦!

 

#include<string.h>
#include<stdio.h>
#define max(a,b) a>b?a:b
int p[1010][1010];
int main()
{
       int T,i,j,len1,len2;
       char str1[1010];
       char str2[1010];
       scanf("%d",&T);
       while(T--)
       {
              memset(p,0,sizeof(p));
              scanf("%s%s",str1,str2);
              len1=strlen(str1);
              len2=strlen(str2);
              for(i=0;i<len1;i++)
              {
                     for(j=0;j<len2;j++)
                     {
                            if(str1[i]==str2[j])p[i+1][j+1]=1+p[i][j];
                            else p[i+1][j+1]=max(p[i][j+1],p[i+1][j]);
                     }
              }
              printf("%d\n",p[len1][len2]);
       }
       return 0;
}

 

这种方法比较笨拙,因为在比较第一个串的第i个时,第二个串只需用到p[i-1][j]或者p[i][j]  (j:1~len2)这两行数,而上面却用到了len1*len2的二维数组,下面的方法是运用滚动数组来优化。可以省下大量的时间和空间(建议在可以看懂第一种的前提下在看这种方法)

 

#include <stdio.h>
#include <string.h>
#define max(a,b) (a)>(b) ? (a) : (b)

char a[1005], b[1005];
short int up[1005], dab[1005];//up存放上一行的数,dad存放新一行的数
short int t, la, lb;

int dp(void)
{
	int i, j;

	memset(up, 0, sizeof(up));
	memset(dab, 0, sizeof(dab));
	for (i = 0; i < la; i++)//两个循环还是一样
	{
		for (j = 0; j < lb; j++)
		{
			if (a[i] == b[j])//如果第一个串的第i个和第二个串的第j个相等
				dab[j+1] = up[j]+1;//就在上一行j-1的基础上加1
			else
				dab[j+1] = max(up[j+1], dab[j]);//否则就取上一行的第j个位置和这一行的第j-1的位置的最大值
		}
		for (j = 0; j <= lb; j++)//数组滚动,更新上一行的数组
			up[j] = dab[j];
	}
	return dab[lb];//返回结果
}

int main()
{
	scanf("%hd", &t);
	while (t--)
	{
		memset(a, 0, sizeof(a));
		memset(b, 0, sizeof(b));
		scanf("%s%s", a, b);
		la = strlen(a);
		lb = strlen(b);
		printf("%hd\n", dp());
	}
	return 0;
}

 

题到此也就告一段落了,但仔细想想,上面的方法其实还是可以在次优化的,每次在找p[i][j]时,用到的只有p[i-1][j-1]  、p[i][j-1] 、 p[i-1][j]  这些值,我们找个变量把它们存起来就好了,如果只用一个数组p[j]在写

p[i-1][j]和p[i][j]其实就是p[j]一个人,只不过是在更新之前当做p[i-1][j]用,更新之后就变成了p[i][j],大家慢慢体会吧、

下面这种做法又优化了大量的时间和空间

 

#include <cstdio>
#include<cstring>
#define max(x,y)  x>y?x:y
char a[1005],b[1005];
int f[1005];
int main()
{
  int T,la,lb,k,k1,i,j;
  scanf("%d",&T);
  while(T--)
  {
      memset(f,0,sizeof(f));
      scanf("%s%s",a,b);
      la=strlen(a);
      lb=strlen(b);
      for(i=0;i<la;i++)
          for(j=0,k1=0;j<lb;j++)
          {   k=f[j+1];//k保存上一行的第j个位置的值
              if(a[i]==b[j]) f[j+1]=k1+1;
              else if(f[j]>f[j+1]) f[j+1]=f[j];//f[j+1]有双重的身份,比较前是上一行的值,比较后就是新一行的值啦!慢慢理解吧
              k1=k;//k1保存上一行的个j-1个位置的值
          }
          printf("%d\n",f[lb]);
  }
}

 

 

 

 

1
9
分享到:
评论

相关推荐

    yolov5-face-landmarks-opencv

    yolov5检测人脸和关键点,只依赖opencv库就可以运行,程序包含C++和Python两个版本的。 本套程序根据https://github.com/deepcam-cn/yolov5-face 里提供的训练模型.pt文件。转换成onnx文件, 然后使用opencv读取onnx文件做前向推理,onnx文件从百度云盘下载,下载 链接:https://pan.baidu.com/s/14qvEOB90CcVJwVC5jNcu3A 提取码:duwc 下载完成后,onnx文件存放目录里,C++版本的主程序是main_yolo.cpp,Python版本的主程序是main.py 。此外,还有一个main_export_onnx.py文件,它是读取pytorch训练模型.pt文件生成onnx文件的。 如果你想重新生成onnx文件,不能直接在该目录下运行的,你需要把文件拷贝到https://github.com/deepcam-cn/yolov5-face 的主目录里运行,就可以生成onnx文件。

    setuptools-0.6c8-py2.5.egg

    文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。

    5-3.py

    5-3

    Java八股文.pdf

    "Java八股文"是一个在程序员社群中流行的术语,特别是在准备技术面试时。它指的是一系列在Java编程面试中经常被问到的基础知识点、理论概念和技术细节。这个术语的命名来源于中国古代科举考试中的“八股文”,一种具有固定格式和套路的文章形式。 在Java编程的上下文中,"Java八股文"通常包括以下几个方面:"Java八股文"是一个在程序员社群中流行的术语,特别是在准备技术面试时。它指的是一系列在Java编程面试中经常被问到的基础知识点、理论概念和技术细节。这个术语的命名来源于中国古代科举考试中的“八股文”,一种具有固定格式和套路的文章形式。 在Java编程的上下文中,"Java八股文"通常包括以下几个方面:"Java八股文"是一个在程序员社群中流行的术语,特别是在准备技术面试时。它指的是一系列在Java编程面试中经常被问到的基础知识点、理论概念和技术细节。这个术语的命名来源于中国古代科举考试中的“八股文”,一种具有固定格式和套路的文章形式。 在Java编程的上下文中,"Java八股文"通常包括以下几个方面:"Java八股文"是一个在程序员社群中流行的术语,特别是在准备技术面试时。它

    麦肯锡咨询顾问必备宝典.ppt

    麦肯锡咨询顾问必备宝典.ppt

    蜉蝣优化算法MA MATLAB源码, 应用案例为函数极值求解以及优化svm进行分类,代码注释详细,可结合自身需求进行应用

    蜉蝣优化算法MA MATLAB源码, 应用案例为函数极值求解以及优化svm进行分类,代码注释详细,可结合自身需求进行应用

    运营主播-课程网盘链接提取码下载 .txt

    运营主播-课程网盘链接提取码下载 .txt

    麦肯锡:xxTII整合营销策略.ppt

    麦肯锡:xxTII整合营销策略.ppt

    Scrapy-0.24.6-py2-none-any.whl

    文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。

    基于matlab虚拟体和人工势场相结合的编队控制算法实现对多个智能体的有效控制源码.zip

    基于matlab虚拟体和人工势场相结合的编队控制算法实现对多个智能体的有效控制源码.zip

    抖音快手挂载小程序-课程网盘链接提取码下载 .txt

    抖音快手挂载小程序-课程网盘链接提取码下载 .txt

    OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习软件库,由

    OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习软件库,由一系列C函数和少量C++类构成,同时提供了Python、Java、MATLAB等语言的接口。它支持在Linux、Windows、Android和Mac OS等多种操作系统上运行,并且具有高效的图像处理和计算机视觉算法,广泛应用于目标检测、人脸识别、图像分割、机器视觉等领域。 OpenCV的主要特点包括: 跨平台:OpenCV支持多种操作系统,并且可以通过不同的编程语言进行访问。 高效:OpenCV实现了许多图像处理和计算机视觉方面的通用算法,并且针对各种处理器进行了优化。 开源:OpenCV是一个开源项目,任何人都可以免费使用和修改其代码。 功能强大:OpenCV提供了丰富的视觉处理算法,包括特征检测、目标跟踪、图像分割、3D重建等。 OpenCV的发展历史可以追溯到1999年,当时Intel公司启动了CVL(Computer Vision Library)项目,旨在开发一个通用的计算机视觉库。随着时间的推移,OpenCV逐渐发展成为一个功能强大且广泛应用

    基于MPC模型预测控制从原理到代码的matlab实现源码+文档说明.zip

    基于MPC模型预测控制从原理到代码的matlab实现源码+文档说明.zip

    XXX公司组织结构诊断报告.ppt

    XXX公司组织结构诊断报告.ppt

    麦肯锡培训手册(2).ppt

    麦肯锡培训手册(2).ppt

    麦肯锡方法 PPT.pps

    麦肯锡方法 PPT.pps

    这是一篇对java八股文的详细介绍的文章

    java八股文

    wireshark安装教程入门.zip

    wireshark安装教程入门 Wireshark 是一款网络协议分析软件。 它可以捕获网络中的数据包,并对这些数据包进行详细的分析和解读,以直观的形式展示网络通信的内容。通过 Wireshark,用户可以查看数据包的源地址、目标地址、协议类型、数据内容等信息,帮助人们深入了解网络中发生的各种活动,如网络故障排查、网络性能评估、安全分析等,是网络工程师、安全研究人员等经常使用的重要工具。

    3-11.py

    3-11

    pytest-6.2.2-py3-none-any.whl

    文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。

Global site tag (gtag.js) - Google Analytics