水题,原来以为用dp数组  结果wrong了两次 我想还是自己小题大做了···呵呵··

献给初学者作为参考

#include <stdio.h>
#include <string.h>
#define MAX 200 int getCommonStrLength(char * pFirstStr, char * pSecondStr)
{
int m = strlen(pFirstStr);
int n = strlen(pSecondStr);
int max = 0;
int number = 0;
if(pFirstStr==NULL||pSecondStr==NULL)
{
return 0;
} for( int i = 0;i < m;i ++)
{
for(int j = 0;j < n;j ++)
{
if(i==m||j==n){break;}
while(pFirstStr[i] == pSecondStr[j])
{
i++;
j++;
number++;
}
if(max < number)
{
max = number;
}
if(i==m||j==n){break;}
} }
return max;
} int main(void)
{
char s1[200] = {
"\0"
}; char s2[200]= {
"\0"
}; scanf("%s",s1);
scanf("%s",s2); int num = getCommonStrLength(s1,s2); printf("%d\n",num); return 0;
}

==========================================

最长公共子串是常见的面试题

出现困惑的是读者对

最长公共子串

最长公共子序列产生混淆

二者的区别是

最长公共子串 要求子串中的单个字符必须都是连续的

最长公共子序列  要求 去掉一部分元素  只要满足 序列中部分的元素 符合某种规律即可

他们处理办法的核心都是一致的

----------------------------------引用自某大神参加面试的总结

子序列跟子串的求法类似,都是使用动态规划的思想,

s1每次增加一个字符,看与s2当前位置的字符是不是相同,如果相同做相应的处理,如果不同,做另外的处理。

子序列的处理方式:

相同的情况下,该二维数组的位置等于[i-1][j-1]+1

不同的情况下,该二维数组的位置等于MAX(d[i-1][j],d[i][j-1])

下面描述下子串的求法。

最长公共子串,要求字符是连续的。那么在[s1每次增加一个字符,看与s2当前位置的字符是不是相同]

相同的情况下,二维数组的位置等于[i-1][j-1]+1,

不同的情况下,二维数组的位置等于0,最后再查看二维数组的信息即可得到最长公共子串的长度,同时可以回溯二维数组得到最长公共字串的内容。

----------------------------------------------------------------------------------------------

上面是正确的算法 错误的算法我也粘贴出来仅供参考

核心

动态规划

dp【i】【j】 表示  串1 从开始字符到 第i个字符 ,串2从开始字符到第j个字符 ,两个串中最常公共子串的个数

满足如下

1.当s1[i] = s2[j]  dp[i][j] = d[i-1][j-1]+1(公共子串满足连续的性质)

2.不等时   dp[i][j] = 0(我不是很理解!求指教,,!!!!!!!!)

#include <stdio.h>

#include <string.h>

#define MAX 200
int dp[MAX][MAX]={
}; int getCommonStrLength(char * pFirstStr, char * pSecondStr)
{
int m = strlen(pFirstStr);
int n = strlen(pSecondStr);
int max = 0; for( int i = 0;i < m;i ++)
{
for(int j = 0;j < n;j ++)
{
if(pFirstStr[i] == pSecondStr[j])
{
if(i ==0 || j == 0)
{
dp[i][j] = 1;
}
else
{
dp[i][j] = dp[i-1][j-1] + 1;
}
} if(max < dp[i][j])
{
max = dp[i][j];
}
} }
return max;
} int main(void)
{
char s1[200] = {
"\0"
}; char s2[200]= {
"\0"
}; memset(dp+2,0,MAX); scanf("%s",s1);
scanf("%s",s2); int num = getCommonStrLength(s1,s2); printf("%d\n",num); return 0;
}

------------------------------ps

后最数组也可实现

kmp算法  也就是字符串查找算法 只要是基于后最数组的都可以实现  (怪不得觉得很眼熟。但是kmp算法却一时想不起来  我哭····)

--------------------------------------------------------------

算法学习还是蛮辛苦的 ,求各位大神指教,给出建议,小弟十分感激

华为 oj 公共子串计算的更多相关文章

  1. 华为OJ: 公共字符串计算

    有几个需要注意的地方,这个问题是不是大写和小写之间的区别.这样你就输入字符串大写或小写转换的计算前. 第二个,定要清晰.先将s1从[i]处開始与s2的[j]開始匹配,不相等则j++直到j等于s2.le ...

  2. 华为OJ之最长公共子串

    题目描述: 对于两个给定的字符串,给出他们的最长公共子串. 题目分析: 1,最长公共子串(LCS)实际上是最长公共子序列的一种特殊情况,相当于是求连续的最长子序列.我们今天先解决这个特殊情况,后续博文 ...

  3. 【ZH奶酪】如何用Python计算最长公共子序列和最长公共子串

    1. 什么是最长公共子序列?什么是最长公共子串? 1.1. 最长公共子序列(Longest-Common-Subsequences,LCS) 最长公共子序列(Longest-Common-Subseq ...

  4. 用Python计算最长公共子序列和最长公共子串

    如何用Python计算最长公共子序列和最长公共子串 1. 什么是最长公共子序列?什么是最长公共子串? 1.1. 最长公共子序列(Longest-Common-Subsequences,LCS) 最长公 ...

  5. 华为OJ2011-最长公共子串

    一.题目描述 描述: 计算两个字符串的最大公共子串(Longest Common Substring)的长度,字符区分大小写. 输入: 输入两个字符串 输出: 输出一个整数 样例输入: asdfas ...

  6. 华为OJ之最长公共子序列

    题目描述: 对于两个给定的字符串,给出他们的最长公共子序列. 题目分析: 1,在之前的博文(http://www.cnblogs.com/yonguo123/p/6711360.html)中我们讨论了 ...

  7. 最长公共子序列PK最长公共子串

    1.先科普下最长公共子序列 & 最长公共子串的区别: 找两个字符串的最长公共子串,这个子串要求在原字符串中是连续的.而最长公共子序列则并不要求连续. (1)递归方法求最长公共子序列的长度 1) ...

  8. lintcode :最长公共子串

    题目 最长公共子串 给出两个字符串,找到最长公共子串,并返回其长度. 样例 给出A=“ABCD”,B=“CBCE”,返回 2 注意 子串的字符应该连续的出现在原字符串中,这与子序列有所不同. 解题 注 ...

  9. 算法设计 - LCS 最长公共子序列&&最长公共子串 &&LIS 最长递增子序列

    出处 http://segmentfault.com/blog/exploring/ 本章讲解:1. LCS(最长公共子序列)O(n^2)的时间复杂度,O(n^2)的空间复杂度:2. 与之类似但不同的 ...

随机推荐

  1. IIS上部署网站404错误

    新装的系统上部署.net网站遇到403.404错误,可能原因记录: 1.应用程序池选择错误,一般选择4.0的 2.ASP.NET4.0应用程序池未安装(一般先安装了framework4.0,后安装ii ...

  2. Java system.getproperty获取环境属性

    序号 属性 说明 1 java.version Java 运行时环境版本 2 java.vendor Java 运行时环境供应商 3 java.vendor.url Java 供应商的 URL 4 j ...

  3. DHTML【2】--HTML

    通过题目,大家已经明确知道,从这一节开始介绍DHTML中的最基础的部分HTML,对于HTML等概念上一节已经做了概述,这一节不再赘余.在学习HTML之前,先告诉大家一个好消息,HTML不难,比C++. ...

  4. [Mugeda HTML5技术教程之4] Studio 概述

    Mugeda Studio 是基于云平台的制作HTML5动画的专业可视化集成开发环境,可以让你在不需要安装客户端程序的情况下,只通过浏览器就能轻松创作高质量的HTML5动画.HTML5动画相对于传统的 ...

  5. php 之 数据访问 增删改查练习题

    练习题内容: 一.查看新闻页面-----主页面: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" ...

  6. table-cell的手机应用场景

    前言 最近在前端观察看见了这篇老文章,看见了元素居中的5种办法,其中提到了display:table-cell这个css显示的新属性,按照当时的浏览器市场来说想必兼容性会是糟糕的一比,但是现在这坛老酒 ...

  7. 【转】 ubuntu12.04更新源 官网和163等

    原文网址:http://blog.csdn.net/zhangliang_571/article/details/8813999 分类: LINUX 摘要: 本文列出ubuntu 12.04 LTS更 ...

  8. linux/unix 段错误捕获【续】

    本文为“在C/C++中捕获段错误,打印出错的具体位置”的续篇,进一步解决涉及动态链接库的情况.   背景知识: ·linux/unix下动态链接库的基本原理 ·/proc/pid/maps文件的基本格 ...

  9. 使IE6同样支持圆角效果

    之前写到过,IE6不支持:hover效果的解决办法,其它这个跟它一样.IE6(7/8)不支持border-radius属性,所以其中的圆角效果显示不出来,可以通过引用ie-css3.htc的方法解决. ...

  10. linux内核--中断和中断处理(一)

        让硬件在需要的时候再向内核发出信号.这就是中断机制,先讨论中断,进而讨论内核如何使用所谓的中断处理函数处理对应的中断. 一.中断   1)中断     中断使得硬件得以发出通知给处理器.例如, ...