题目
描述
编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 ""。
示例 1:
代码语言:javascript复制输入: ["flower","flow","flight"]
输出: "fl"
示例 2:
代码语言:javascript复制输入: ["dog","racecar","car"]
输出: ""
解释: 输入不存在公共前缀。
来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/longest-common-prefix 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解答
思路
遍历数组中的每个字符串,利用String对象的startsWith方法,依次找到最长公共前缀。其中如果缓存前缀字母扣减到0个,可以直接返回。
代码
代码语言:javascript复制class Solution {
public String longestCommonPrefix(String[] strs) {
StringBuilder r = new StringBuilder();
if (strs.length == 0) {
return "";
}
if (strs.length == 1) {
return strs[0];
}
String s = strs[0];
for (String str : strs) {
while (!str.startsWith(s)) {
if (s.length() == 1) {
return "";
}
s = s.substring(0, s.length() - 1);
}
}
return s;
}
}