14.最长公共前缀
编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 “”。
示例 1:
输入: [“flower”,“flow”,“flight”]
输出: “fl”
示例 2:
输入: [“dog”,“racecar”,“car”]
输出: “”
解释: 输入不存在公共前缀。
说明:
所有输入只包含小写字母 a-z 。
解题思路
我的做法比较笨,也就是类似于BF算法那样,暴力匹配,如果遇到不匹配的直接记录下来位置,返回前缀长度。
只不过该方法一定要注意几个坑:
- 第一个位置的字符串长度如果为大于后面其它的字符串怎么处理
- 遇到空字符数组和第一个字符串数组第一个元素为 ""的处理
- 两层循环如何跳出
代码
class Solution {
public String longestCommonPrefix(String[] strs) {
int i = 0,k=0;
boolean flag = true;
//如果长度为1
if (strs.length == 1) {
return strs[0];
}
//数组第一个元素为""处理
if(strs.length == 0 || strs[0].length() ==0){
return "";
}
//开始循环
outterLoop:while (i < strs[0].length()) {
char c = strs[0].charAt(i);
//m控制除0位置的其它字符串下标
int m = 1;
while ( m < strs.length ) {
if (k < strs[m].length() && c != strs[m].charAt(k)) {
flag = false;
break outterLoop;
//后面的字符串字符越界
}else if(!(k < strs[m].length())){
break outterLoop;
}
m++;
}
//k控制的是除0位置其它字符串的字符位置
k++;
//控制0位置的字符
i++;
}
return strs[0].substring(0, k);
}
}
测试
做题不能盲目提交,不然自己会受到打击!