1.题目描述:
编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 “”。
示例 1:
输入:strs = [“flower”,“flow”,“flight”]
输出:“fl”
示例 2:
输入:strs = [“dog”,“racecar”,“car”]
输出:""
解释:输入不存在公共前缀。
2.代码实现:
1.横向扫描:
横向扫描:依次遍历每个字符串,更新最长公共前缀
思路步骤:
1.单独将字符串数组中的第一个字符串取出来作为前缀(prefix)。
2.从字符串中中第二个字符串开始遍历。
3.俩俩开始比较。( comparePrefix(String1 ,String2) )
4.先得到在比较的两个字符串的最短长度。
5.设置变量 index ,当index < 最短长度 且String1.charAt(index) == String2.charAt(index) 进行遍历
6.index++;
7.当不相等时,遍历结束。
8.得到一个新字符串,String.substring(0,index):是从0到index分割字符串得到一个新的字符串。
代码:
class Solution {
public String longestCommonPrefix(String[] strs) {
if (strs == null || strs.length == 0) {
return "";
}
String prefix = strs[0];
int count = strs.length;
for (int i = 1; i < count; i++) {
prefix = comparePrefix(prefix, strs[i]);
if (prefix.length() == 0) { //当没有相同的前缀时,返回的是空字符串。
break;
}
}
return prefix;
}
public String comparePrefix(String str1, String str2) {
int length = Math.min(str1.length(), str2.length());
int index = 0;
while (index < length && str1.charAt(index) == str2.charAt(index)) {
index++;
}
return str1.substring(0, index);
}
}
2.纵向扫描:
纵向扫描:从前往后遍历所有字符串的每一列,比较相同列上的字符是否相同。
思路步骤:
1.得到字符串数组中第一个数组的长度 length。(方便计数,无关那个字符串最长、最短)
2.对第一个字符串进行遍历,同时取出对应下标的字符 c;
3.对字符串数组从1开始遍历。
4.如果遍历时遇到最短长度的字符串 或者 对应下标字符:c 不等于 某个字符串对应下标的字符时 退出循环。
代码:
class Solution{
public String longestCommonPrefix(String[] strs) {
if (strs == null || strs.length == 0) {
return "";
}
int length = strs[0].length();
int count = strs.length;
for (int i = 0; i < length; i++) {
char c = strs[0].charAt(i);
for (int j = 1; j < count; j++) {
if (i == strs[j].length() || strs[j].charAt(i) != c) {
return strs[0].substring(0, i);
}
}
}
return strs[0];
}
}