14.最长公共前缀

编写一个函数来查找字符串数组中的最长公共前缀。

如果不存在公共前缀,返回空字符串 “”。

示例 1:

输入: [“flower”,“flow”,“flight”]
输出: “fl”
示例 2:

输入: [“dog”,“racecar”,“car”]
输出: “”
解释: 输入不存在公共前缀。
说明:

所有输入只包含小写字母 a-z 。

解题思路


我的做法比较笨,也就是类似于BF算法那样,暴力匹配,如果遇到不匹配的直接记录下来位置,返回前缀长度。

只不过该方法一定要注意几个坑:

  1. 第一个位置的字符串长度如果为大于后面其它的字符串怎么处理
  2. 遇到空字符数组和第一个字符串数组第一个元素为 ""的处理
  3. 两层循环如何跳出

代码

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);
    }
}

测试

做题不能盲目提交,不然自己会受到打击!