用 JavaScript 寻找最长的“不常见”字符串
我们需要编写一个 JavaScript 函数,它接受一个字符串数组。该函数应在数组的字符串中找到最长的不常见子序列。
最长的不常见子序列是指这些字符串中的最长子序列,而且该子序列不应是其他字符串的任何子序列。
我们的函数应返回这个最长不常见子序列的长度。
例如:如果输入数组为 −
const arr = ["aba", "cdc", "eae"];
那么输出应为 3。
示例
此代码为 −
const arr = ["aba", "cdc", "eae"]; const findUncommonLength = (array = []) => { const seen = {}; const arr = []; let max = −1; let index = −1; for(let i = 0; i < array.length; i++){ seen[array[i]] = (seen[array[i]] || 0) + 1; if(seen[array[i]] > 1){ if(max < array[i].length){ max = array[i].length index = i; } } }; if(index === −1) { array.forEach(el =>{ if(el.length > max) max = el.length; }) return max; }; for(let i = 0; i < array.length; i++){ if(seen[array[i]] === 1) arr.push(array[i]); }; max = −1; for(let i = arr.length − 1; i >= 0; i−−){ let l = arr[i]; let d = 0; for(let j = 0; j < array[index].length; j++){ if(array[index][j] === l[d]){ d++; } } if(d === l.length){ let temp = arr[i]; arr[i] = arr[arr.length − 1]; arr[arr.length − 1] = temp; arr.pop(); } }; arr.forEach(el =>{ if(el.length > max) max = el.length; }); return max; }; console.log(findUncommonLength(arr));
输出
并且控制台中的输出将为 −
3
广告