题目
编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 “”。
示例 1:
输入: [“flower”,“flow”,“flight”]
输出: “fl”
示例 2:
输入: [“dog”,“racecar”,“car”]
输出: “”
解释: 输入不存在公共前缀。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/longest-common-prefix
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
- 分析
1.两个字符串a,b的公共串:
n=min(a.length(),b.length())
遍历(0…n),找出对应位置的字符,第一次出现不同的位置position;
返回a.subString(0,position);
2.多个String,依次比较即可。
public String longestCommonPrefix(String[] strs) {
if(strs.length==0){
return "";
}
int size=strs.length;
String common=strs[0];
for(int i=1;i<size;i++){
int j;
for(j=0;j<Math.min(common.length(),strs[i].length());j++){
if(common.charAt(j)!=strs[i].charAt(j)){
break;
}
}
common=common.substring(0,j);
}
return common;
}
优化
public String longestCommonPrefixPro(String[] strs) {
int size = strs.length;
if (size == 0) {
return "";
}
int minPosition = strs[0].length();
for(int i=1;i<size;i++){
if(strs[i].length()<minPosition){
minPosition=strs[i].length();
}
}
for (int i = 1; i < size; i++) {
for(int j=0;j<minPosition;j++){
if(strs[i-1].charAt(j)!=strs[i].charAt(j)){
minPosition=j;
}
}
}
return strs[0].substring(0,minPosition);
}