编写一个函数来查找字符串数组中的最长公共前缀。如果不存在公共前缀,返回空字符串 ""。
示例 1:
输入:strs = ["flower","flow","flight"]
输出:"fl"
示例 2:
输入:strs = ["dog","racecar","car"]
输出:""
解释:输入不存在公共前缀。
提示:
1 <= strs.length <= 200
0 <= strs[i].length <= 200
strs[i] 仅由小写英文字母组成
解法一
假设第0个元素是公共前缀,记为 prefix,从数组的第1个元素开始遍历,每得到一个元素 str,用内层循环让 str 与 prefix 同位置的字符对比,当对比到不相同的字符时,推出内层循环,将 prefix 改为 str 与 prefix 公共部分
ts
function longestCommonPrefix(strs: string[]): string {
let prefix = strs[0]
for(let i = 1; i < strs.length; i++) {
if (!prefix) {
break
}
const str = strs[i]
let j = 0
while(prefix[j] && str[j]) {
if (prefix[j] !== str[j]) {
break
}
j++
}
prefix = prefix.slice(0,j)
}
return prefix
};
解法二
与解法一思路一样,只是用 str.indexOf(prefix) 修改内层 while 循环中 prefix 与 str 的匹配
ts
function longestCommonPrefix(strs: string[]): string {
let prefix = strs[0]
for(let i = 1; i < strs.length; i++) {
if (!prefix) {
break
}
const str = strs[i]
while(str.indexOf(prefix) !== 0) {
prefix = prefix.slice(0,-1)
}
}
return prefix
};
解法一假定 prefix 的最小与 str 匹配,解法二假定 prefix 的最大与 str 匹配