Leetcode-14. 最长公共前缀
2020-05-30 本文已影响0人
悠扬前奏
题目
描述
编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 ""。
示例 1:
输入: ["flower","flow","flight"]
输出: "fl"
示例 2:
输入: ["dog","racecar","car"]
输出: ""
解释: 输入不存在公共前缀。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/longest-common-prefix
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解答
思路
遍历数组中的每个字符串,利用String对象的startsWith方法,依次找到最长公共前缀。其中如果缓存前缀字母扣减到0个,可以直接返回。
代码
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;
}
}