当前位置:首页 » 公共卫生 » 公共子串

公共子串

发布时间: 2020-11-21 10:51:48

Ⅰ 各位高手,怎么编找出N个字符串的公共子串

个人对编程有点爱好,就胡乱说些方案吧。

问题的意思是否是说从N个随机的字符串中找出都包含的相同的子串,如下:ABCDSD,ASDCDAB,ADOABDCD3,AXDABCDSA,在这四个字符串中都包含有AB和CD,这个公共子串是否是自动查找?还是手动设定?这个相差很大。还有这个公共子串是否有长度限制,最少两个字符?通过长度限制,从第一个字符串开始进行分解,遍历N-1个字符串,然后如果每个字符串中都包含第一个字符串中分解出来的子串,则就找到一个,然后继续分解完最后全部的排序。如ABCDSD,可以分解为AB,ABC,ABCD,ABCDS,ABCDSD五种子串。
当然,如果字符串的长度可以是随机的,只需要找到长度最短的那个进行遍历就可以了。

Ⅱ 求两个输入的字符串的最长公共子串

  1. 算法:求两个字符串的最长公共子串

  2. 原理:

(1) 将连个字符串分别以行列组成一个矩阵。

(2)。若该矩阵的节点对应的字符相同,则该节点值为1。

(3)当前字符相同节点的值 = 左上角(d[i-1, j-1])的值 +1,这样当前节点的值就是最大公用子串的长。

(s2)bcde

(s1)

a0000

b1000

c0200

d0030

3. 结果:只需以行号和最大值为条件即可截取最大子串

C# code:

[csharp]view plainprint?

publicstaticstringMyLCS(strings1,strings2)

{

if(String.IsNullOrEmpty(s1)||String.IsNullOrEmpty(s2))

{

returnnull;

}

elseif(s1==s2)

{

returns1;

}

intlength=0;

intend=0;

int[,]a=newint[s1.Length,s2.Length];

for(inti=0;i<s1.Length;i++)

{

for(intj=0;j<s2.Length;j++)

{

intn=(i-1>=0&&j-1>=0)?a[i-1,j-1]:0;

a[i,j]=s1[i]==s2[j]?1+n:0;

if(a[i,j]>length)

{

length=a[i,j];

end=i;

}

}

}

returns1.Substring(end-length+1,length);

}

Ⅲ 求助 公共子串

从公共串的第一个字母开始,查询三个串,一旦发现全等则输出,并开始确定公共串的下一个字母;当然还要避免重复

这是c语言的,运行没问题
而且题目要求是50个字符以内,该算法复杂度就在50^3即0.1M左右,不算大

#include <stdio.h>
#include <string.h>
#include <malloc.h>
//A,B,C分别表示输入的三个串,R用来记录一次公共子串
char A[51],B[51],C[51],R[51];
//LA,LB,LC分别表示ABC的字符串长,Num表示公共子串个数
int LA,LB,LC,Num;
//函数的功能:从A,B,C串的第sta,stb,stc位置开始
//查找相等项,查找成功则放入R串的level位置,并进而
//确认R串的下一位置level+1的应填入值
//查找会匹配三个串从sta,stb,stc开始的每个位置
void fun(int sta,int stb,int stc,int level)
{
//table是记录该位置此字母出现过没有
int *table=(int*)malloc(104);
int i,j,k;
memset(table,0,104);
//查询三个串,寻找全等
for(i=sta;i<LA;i++)
for(j=stb;j<LB;j++)
for(k=stc;k<LC;k++)
if(A[i]==B[j]&&B[j]==C[k])
//如果字母没出现过,则可以输出
if(!table[A[i]-97])
{
R[level]=A[i];
//置表项字母为已出现
table[A[i]-97]=1;
puts(R);
Num++;
//开始确认下个字母
fun(i+1,j+1,k+1,level+1);
}
free(table);
R[level]=0;
}
main()
{
puts("输入字符串");
scanf("%50s%50s%50s",A,B,C);
puts("________________");
LA=strlen(A),LB=strlen(B),LC=strlen(C);
//从三个串头开始查找,首先确认的是R的第0位置
fun(0,0,0,0);
printf("公共子串有%d个",Num);
}

Ⅳ 数据结构求公共子串问题

#include <iostream>
#include <string>
#include <math.h>
using namespace std;

int main()
{
string str1,str2;
while (cin>>str1>>str2)
{
int m=str1.size(),n=str2.size();
int**ptr=new int*[m+1];
for (int i=0;i<=m;i++)
{
ptr[i]=new int [n+1];
}
for (int i=0;i<m;i++)
ptr[i][0]=0;
for (int i=0;i<n;i++)
ptr[0][i]=0;
for (int i=1;i<=m;i++)
{
for (int j=1;j<=n;j++)
{
if(str1.at(i-1)==str2.at(j-1))
{ptr[i][j]=ptr[i-1][j-1]+1;cout<<ptr[i][j]<<ends;}
else
{ptr[i][j]=ptr[i-1][j]>ptr[i][j-1]?ptr[i-1][j]:ptr[i][j-1];cout<<ptr[i][j]<<ends;}
}
}
cout<<ptr[m][n]<<endl;
}

return 0;
}

用的是动态规划的知识;

思想是这样的:

Ⅳ 求两个字符串最大公共子串问题

已改,看注释

#include<stdio.h>
#include<malloc.h>
#include<string.h>
#include<stdlib.h>
#define MaxSize 100
typedef struct
{
char str[MaxSize] ;
int len ;
}SeqString ;

int SubSeqString( SeqString *Sub , SeqString S , int pos , int len )
{
int i ;
if( pos < 0 || pos > S.len || len > S.len - pos || len < 1 )
{
Sub -> len = 0 ;
return 0 ;
}
else
{
for( i = 0 ; i < len ; i ++ )
{
Sub -> str[i] = S.str[i+pos] ;
}
Sub->str[i] = '\0'; // 字符串结束
Sub -> len = len ;
return 1 ;
}
}

int MaxSameSeqString( SeqString S , SeqString T , SeqString *M )
{
int i , j , k , t , pos ;
int len = 0 , maxlen = 0 ;
for( i = 0 ; i < S.len ; i++ )
{
k = i ;

for( j = 0 ; j < T.len ; j++ )
{
t = j ;
len = 0; // len赋值0
if( S.str[i] == T.str[j] )
{
while( S.str[k++] == T.str[t++] )
len++ ;
if( maxlen < len )
{
maxlen = len ;
pos = i ;
}
}
}
}
if( maxlen >= 1 )
{
SubSeqString( M , S , pos , maxlen ) ; // 参数是maxlen,不是len
return 1 ;
}
return 0 ;
}

int main()
{
SeqString X , Y ;
SeqString *R = (SeqString*)malloc(sizeof (SeqString));
char a[MaxSize] , b[MaxSize] ;
scanf( "%s" , a ) ;
scanf( "%s" , b ) ;
int alen , blen ;
alen = strlen(a) ;
blen = strlen(b) ;
X.len = alen ;
Y.len = blen ;
strcpy( X.str , a ) ;
strcpy( Y.str , b ) ;
MaxSameSeqString( X , Y , R ) ;
printf("%s" , R -> str );

return 0 ;}

Ⅵ C语言:“最长公共子串” 高手帮忙编个

描述]
现在有一些由英文字符组成的大小写敏感的字符串,你的任务是找到一个最长的字符串[x],使得对于已经给出的字符串中的任意一个y,[x]或[反序后的x]是y的子串。

[关于输入]
输入的第一行是一个整数t (1 <= t <= 10),t表示测试数据的数目。对于每一组测试数据,第一行是一个整数n (1 <= n <= 100),表示已经给出n个字符串。接下来n行,每行给出一个长度在1和100之间的字符串。

[关于输出]
对于每一组测试数据,输出一行,给出题目中要求的字符串x的长度。

Ⅶ 寻找最长公共子串(高分)

我是北京某大学的学生,前天实习时完美解决了此题。
这里人多,我怕暴露了身回份
http://netalpha.javaeye.com/blog/340554
相对的,答如果您有另一题的编码,就是解释程序的,请务必告诉我。

现有一些由英文字符组成的大小写敏感的字符串。编写一个程序,找到一个最长的字符串x,使得:对于已经给出的字符串中的任意一个y, x或者是y的子串、或者x中的字符反序之后得到的新字符串是y的子串。

Ⅷ 用C语言编写求两个字符串的公共子串!在线等!

靠,我们书上的例子。。
#include<stdio.h>
#include<string.h>
#define m 30
typedef struct
{char vec[m];
int len;
}orstr;
void maxstr(orstr *s1,orstr *s2)
{int index=0,long2=0,i,j,k,long1;
i=0;
while(i<s1->len)
{j=0;
while(j<s2->len)
{if(s1->vec[i]==s2->vec[j])
{long1=1;
for(k=1;s1->vec[i+k]==s2->vec[j+k];k++)long1=long1+1;
if(long1>long2)
{index=i;
long2=long1;
}
j+=long1;
}
else
j++;
}
i++;
}
printf("最长的公共子串:");
for(i=0;i<long2;i++)printf("%c",s1->vec[index+i]);
}
main()
{orstr *s1,*s2;
strcpy(s1->vec,"*******");//这里是要你输入的字符串
s1->len=**;//这里要填你输入的字符串个数
strcpy(s2->vec,"*******");//这里是要你输入的字符串
s2->len=**;//这里要填你输入的字符串个数
maxstr(s1,s2);
}

Ⅸ 最长公共子串

又是楼主?好像这个问题已经回答过了
下面的程序是符合楼主要求的程序
//作者:hacker
//时间:9.12.2006
#include <stdio.h>
#include <string.h>

void main()
{
char* x="aabcdababce";
char* y="12abcabcdace";
int m = strlen(x);
int n = strlen(y);
int i, j, k, l;
int maxlength = 0;
int start = 0;
int count = 0;//用来判断是否匹配的变量

for (i=1;i<=n;i++)//匹配长度的循环
for (j=0;j<n-i+1;j++)//y的起始位置的循环
for (k=0;k<m-i+1;k++)//x的起始位置的循环
{
count = 0;
for (l=0;l<i;l++)//判断是否匹配,代码可以优化
if (y[j+l] == x[k+l])
count++;
if (count==i&&i>maxlength)
{
maxlength = i;//记录最大长度
start = j;//记录最大长度的起起位置
}
}

if (maxlength==0)
printf("No Answer");
else
for (i=0;i<maxlength;i++)
printf("%c",y[start+i]);
}

下面的程序是真正的最长公共子串的程序
//作者:hacker
//时间:9.12.2006

#include <stdio.h>
#include <string.h>

int b[50][50];
int c[50][50];

void lcs(x,m,y,n)
char *x;
int m;
char *y;
int n;
{
int i;
int j;

for (i=1;i<=m;i++) c[i][0] = 0;
for (i=1;i<=n;i++) c[0][i] = 0;
c[0][0] = 0;
for (i=1;i<=m;i++)
for (j=1;j<=n;j++)
{
if (x[i-1] == y[j-1])
{
c[i][j] = c[i-1][j-1] + 1;
b[i][j] = 1;
}
else
if (c[i-1][j] > c[i][j-1])
{
c[i][j] = c[i-1][j];
b[i][j] = 2;
}
else
{
c[i][j] = c[i][j-1];
b[i][j] = 3;
}

}
}

void show(i,j,x)
int i;
int j;
char* x;
{
if (i==0||j==0)
return;
if (b[i][j]==1)
{
show(i-1,j-1,x);
printf("%c",x[i-1]);
}
else
if (b[i][j]==2)
show(i-1,j,x);
else
show(i,j-1,x);
}

void main()
{
char* x="aabcdababce";
char* y="12abcabcdace";
int m = strlen(x);
int n = strlen(y);
lcs(x,m,y,n);
show(m,n,x);

}

Ⅹ 求最长公共子串 递归写的

//刚写的!
publicclassStringTest{
publicstaticvoidmain(String[]args){
Strings1="321abcDEFG123456";
Strings2="45DEFG123489";
Stringstr=method(s1,s2,0,s2.length(),3>2);
System.out.println(" "+s1+" "+s2+" 最大公共子串=>"+str);
}
privatestaticStringmethod(Strings1,Strings2,intt,intw,booleanb){
if(t>=w)returnnull;
Stringstr=s2.substring(t,w);
if(s1.contains(str))
returnstr;
else
if(b)
returnmethod(s1,s2,++t,w,b=!b);
else
returnmethod(s1,s2,t,--w,b=!b);
}
}

热点内容
影视转载限制分钟 发布:2024-08-19 09:13:14 浏览:319
韩国电影伤口上纹身找心里辅导 发布:2024-08-19 09:07:27 浏览:156
韩国电影集合3小时 发布:2024-08-19 08:36:11 浏览:783
有母乳场景的电影 发布:2024-08-19 08:32:55 浏览:451
我准备再看一场电影英语 发布:2024-08-19 08:14:08 浏览:996
奥迪a8电影叫什么三个女救人 发布:2024-08-19 07:56:14 浏览:513
邱淑芬风月片全部 发布:2024-08-19 07:53:22 浏览:341
善良妈妈的朋友李采潭 发布:2024-08-19 07:33:09 浏览:760
哪里还可以看查理九世 发布:2024-08-19 07:29:07 浏览:143
看电影需要多少帧数 发布:2024-08-19 07:23:14 浏览:121