14. 最长公共前缀
编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 ""
。
示例 1:
输入: ["flower","flow","flight"] 输出: "fl"
示例 2:
输入: ["dog","racecar","car"] 输出: "" 解释: 输入不存在公共前缀。
说明:
所有输入只包含小写字母 a-z
。
class Solution {
public String longestCommonPrefix(String[] strs) {
//判断是否为空串
//当字符串数组长度为 0 时则公共前缀为空,直接返回
if(strs.length == 0){
return "";
}
//申请存放公共前缀的变量
//令最长公共前缀 ans 的值为第一个字符串,进行初始化
String ans = strs[0];
//遍历后面的字符串,依次将其与 ans 进行比较
//两两找出公共前缀,最终结果即为最长公共前缀
for(int i = 1; i < strs.length; i++){
//初始化标记下标
int j;
for(j = 0; j < ans.length() && j < strs[i].length(); j++){
if(ans.charAt(j) != strs[i].charAt(j)){
break;
}
}
//将相同的部分切分
ans = ans.substring(0,j);
//如果查找过程中出现了 ans 为空,则公共前缀不存在直接返回
if(ans.equals("")){
return ans;
}
}
//返回最终结果
return ans;
}
}
/*时间复杂度:O(s),s 为所有字符串的长度之和*/