问题描述
编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 “”。
示例 1:
输入: [“flower”,“flow”,“flight”]
输出: “fl”
示例 2:
输入: [“dog”,“racecar”,“car”]
输出: “”
解释: 输入不存在公共前缀。
说明:
所有输入只包含小写字母 a-z 。
解题思路
- 首先是边界值的考虑,除了参数判断外,这里如果有一个元素的长度为0,则直接返回“”,不需要再判断,这是容易疏忽的一点
- 然后拿最小长度的元素遍历,这样就不会出现数组越界
- 遍历最小长度,取第一个元素分别与其他元素做比较,从第一位开始,比较到最小长度为止
- 比较中,如果不相同则直接返回结果,相同的,在外层,也就是遍历元素最小长度层记录值即可,(最小长度,就是比较元素的个数,这里用StringBuileder会更快)
实现
public class LongestCommonPrefix {
public String longestCommonPrefix(String[] strs) {
if(strs==null||strs.length==0){
return "";
}
int len = strs[0].length();
for(String s:strs){
len = Math.min(len,s.length());
}
if(len ==0){
return "";
}
StringBuilder stringBuilder = new StringBuilder(len);
for(int i=0;i<len;i++){//第一个元素各个字母
for(int j=1;j<strs.length;j++){//元素个数
if(strs[0].charAt(i)!=strs[j].charAt(i)){
return stringBuilder.toString();
}
}
stringBuilder.append(strs[0].charAt(i));
}
return stringBuilder.toString();
}
}
别人更优美的代码
public static String longestCommonPrefix1(String[] strs) {
int count = strs.length;
String prefix = "";
if(count != 0){
prefix = strs[0];
}
for(int i=0; i<count; i++){
//关键代码,不断的从后往前截取字符串,然后与之相比,直到startsWith()返回true
while(!strs[i].startsWith(prefix)){
prefix = prefix.substring(0, prefix.length()-1);
}
}
return prefix;
}
描述:
{“flower”,“flow”,“flight”};
取第一个元素为基准值flower,遍历数组长度,第一个的时候flower是以flower开头,遍历下一个,flow不是以flower开头,则把flower截断1位,为flowe,再判断直到变为flow,遍历下一个元素,flight不是以flow开头,截断一位,直至fl,for遍历结束,返回结果。
很巧妙。