在 JavaScript 中找到两个字符串中最长的公共连续子字符串
我们要求编写一个 JavaScript 函数,该函数接受两个字符串。我们称它们为 str1 和 str2。然后,该函数应该找出这两个输入字符串中最长的连续字符串,并返回该公共字符串。
例如 -
如果输入字符串为 -
const str1 = 'ABABC'; const str2 = 'BABCA';
那么输出字符串应该是 -
const output = 'BABC';
示例
以下是代码 -
const str1 = 'ABABC';
const str2 = 'BABCA';
const findCommon = (str1 = '', str2 = '') => {
const s1 = [...str1];
const s2 = [...str2];
const arr = Array(s2.length + 1).fill(null).map(() => {
return Array(s1.length + 1).fill(null);
});
for (let j = 0; j <= s1.length; j += 1) {
arr[0][j] = 0;
}
for (let i = 0; i <= s2.length; i += 1) {
arr[i][0] = 0;
}
let len = 0;
let col = 0;
let row = 0;
for (let i = 1; i <= s2.length; i += 1) {
for (let j = 1; j <= s1.length; j += 1) {
if (s1[j - 1] === s2[i - 1]) {
arr[i][j] = arr[i - 1][j - 1] + 1;
}
else {
arr[i][j] = 0;
}
if (arr[i][j] > len) {
len = arr[i][j];
col = j;
row = i;
}
}
}
if (len === 0) {
return '';
}
let res = '';
while (arr[row][col] > 0) {
res = s1[col - 1] + res;
row -= 1;
col -= 1;
}
return res;
};
console.log(findCommon(str1, str2));输出
以下是控制台上的输出 -
BABC
广告
数据结构
网络
RDBMS
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP