内容:
采用顺序结构存储串,设计实现求串s和串t的一个最长公共子串的算法。
步骤:
- 算法分析
本题算法采用顺序存储结构求串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;
}