分类:字符串
题目描述
给定字符串列表,你需要从它们中找出最长的特殊序列。最长特殊序列定义如下:该序列为某字符串独有的最长子序列(即不能是其他字符串的子序列)。
子序列可以通过删去字符串中的某些字符实现,但不能改变剩余字符的相对顺序。空序列为所有字符串的子序列,任何字符串为其自身的子序列。
输入将是一个字符串列表,输出是最长特殊序列的长度。如果最长特殊序列不存在,返回 -1 。
示例:
输入: "aba", "cdc", "eae"
输出: 3
提示:
- 所有给定的字符串长度不会超过 10 。
- 给定字符串列表的长度将在 [2, 50 ] 之间。
思路:
遍历字符串数组,判断每一个字符是不是最长特殊序列
代码实现:
/**
* @param {string[]} strs
* @return {number}
*/
var findLUSlength = function (strs) {
strs.sort((a, b) => b.length - a.length);
for (let i = 0; i < strs.length; i++) {
if (help(strs, i)) {
return strs[i].length;
}
}
return -1;
};
function help(arr, k) {
// 判断位置为k的字符是否独一无二,且不属于比他长的子序列
let c = arr[k];
let flag = arr.indexOf(c) == arr.lastIndexOf(c);
for (let i = 0; i < k; i++) {
if (valid(arr[i], c)) return false;
}
return flag;
}
function valid(a, b) {
// 判断b是否是a的子序列
if (a.indexOf(b) != -1) return true;
let i = 0, j = 0;
while (i < a.length) {
if (a.charAt(i) == b.charAt(j)) {
j++;
if (j == b.length) return true;
}
i++;
}
return false;
}
运行结果: