求最长公共子串

内容:

   采用顺序结构存储串,设计实现求串s和串t的一个最长公共子串的算法。

步骤:

  1. 算法分析

   本题算法采用顺序存储结构求串s和串t的最大公共子串。串1用i指针,串2用t指针,对每个i,求从i开始的连续字符串与从j开始的连续字符串的最大匹配。当字符串1中某字符SeqString1[i + j] 与字符串2中某字符 SeqString2[j]相等时,求出局部公共子串。若该字串长度大于已求出的最长公共子串max,则最长公共子串的长度Max要修改。

2.概要设计 

使用C语言,其中设置了以下函数

3.程序运行流程图如下:

 

 4.测试

测试案例:

测试用例涵盖:输入的字符为纯数字,输入的字符为纯字母,输入的字符既有字母又有数字,输入的字符含有空格等问题,提供较多测试用例,保证测试效果。

 测试结果:

 测试结果显示当输入纯数字,纯字母,数字与字母组合的字符串时均可正常运行输出最长公共子串,当输入的字符串中含有空格时,程序运行时忽略空格,输出公共子串,如案例四所示。

5.源码如下:

#include<stdio.h>
#include<string.h>
//定义顺序表 
typedef struct SeqString {
	char ch[100];//定义数组最大长度 
	int top=0;
	int length;
} SeqString;
int main() {
	char SeqString1[100], SeqString2[100];
	printf("请输入字符串1:");
	gets(SeqString1);
	getchar;
	printf("请输入字符串2:");
	gets(SeqString2);
	int max = 0;
	int i, j;
	int len1 = strlen(SeqString1);
	int len2 = strlen(SeqString2);
	SeqString str[100];
	int n = 0;
	int MAX=0;
	for (i = 0; i < len1; i++) {
		for (j = 0; j < len2; j++) {
			if (SeqString1[i + j] == SeqString2[j]) {
				max++;
				str[n].ch[str[n].top] = SeqString2[j];
				str[n].top++;
			} else {
				str[n].ch[str[n].top] = '\0';
				str[n].length = max;
				if (max > MAX)
					MAX = max;
				max = 0;
				n ++;
			}
		}
	}

	printf("最长为%d\n最长公共子串为:", MAX);

	for (int k = 0; k < n; k++) {
		if (str[k].length == MAX)
			puts(str[k].ch);
	}

	return 0;
}

  • 2
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值