Leetcode __14. 最长公共前缀

问题描述

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

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

示例 1:

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

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

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

解题思路

  • 首先是边界值的考虑,除了参数判断外,这里如果有一个元素的长度为0,则直接返回“”,不需要再判断,这是容易疏忽的一点
  • 然后拿最小长度的元素遍历,这样就不会出现数组越界
  • 遍历最小长度,取第一个元素分别与其他元素做比较,从第一位开始,比较到最小长度为止
  • 比较中,如果不相同则直接返回结果,相同的,在外层,也就是遍历元素最小长度层记录值即可,(最小长度,就是比较元素的个数,这里用StringBuileder会更快)

实现

public class LongestCommonPrefix {
    public String longestCommonPrefix(String[] strs) {
        if(strs==null||strs.length==0){
            return "";
        }
        int len = strs[0].length();
        for(String s:strs){
            len = Math.min(len,s.length());
        }
        if(len ==0){
            return "";
        }
        StringBuilder stringBuilder = new StringBuilder(len);
        for(int i=0;i<len;i++){//第一个元素各个字母
            for(int j=1;j<strs.length;j++){//元素个数
                if(strs[0].charAt(i)!=strs[j].charAt(i)){
                    return stringBuilder.toString();
                }

            }
            stringBuilder.append(strs[0].charAt(i));
        }
        return stringBuilder.toString();

    }
}

别人更优美的代码


    public static String longestCommonPrefix1(String[] strs) {
        int count = strs.length;
        String prefix = "";
        if(count != 0){
            prefix = strs[0];
        }
        for(int i=0; i<count; i++){
            //关键代码,不断的从后往前截取字符串,然后与之相比,直到startsWith()返回true
            while(!strs[i].startsWith(prefix)){
                prefix = prefix.substring(0, prefix.length()-1);
            }
        }
        return prefix;
    }

描述:
{“flower”,“flow”,“flight”};
取第一个元素为基准值flower,遍历数组长度,第一个的时候flower是以flower开头,遍历下一个,flow不是以flower开头,则把flower截断1位,为flowe,再判断直到变为flow,遍历下一个元素,flight不是以flow开头,截断一位,直至fl,for遍历结束,返回结果。
很巧妙。

猜你喜欢

转载自blog.csdn.net/Growing_way/article/details/83506555