最长公共前缀(力扣 14)Java打败100%提交记录

人生之路不会是一帆风顺的,我们会遇上顺境,也会遇上逆境,在所有成功路上折磨你的,背后都隐藏着激励你奋发向上的动机,人生没有如果,只有后果与结果,成熟,就是用微笑来面对一切小事。

导读:本篇文章讲解 最长公共前缀(力扣 14)Java打败100%提交记录,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

目录

一、题目描述

二、思路讲解

三、Java代码实现

四、时空复杂度分析 

五、代码优化


 

一、题目描述

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

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

示例 1:

输入:strs = [“flower”,”flow”,”flight”]
输出:”fl”

示例 2:

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

提示:

1 <= strs.length <= 200
0 <= strs[i].length <= 200
strs[i] 仅由小写英文字母组成

二、思路讲解

        逐位更新公共前缀。将所有字符串的第i位(从0开始)与第一个字符串的第i位比较。如果第i位都相同,说明是相同前缀,将它追加到要返回的字符串s(初始为空串)上;如果有不相同,直接返回 s;

三、Java代码实现

class Solution {
    public String longestCommonPrefix(String[] strs) {

        String s = "";
        int len = strs[0].length();
        for(int i=0; i<strs.length; i++){
            if(len > strs[i].length()){
                len = strs[i].length();
            }
        }

        for(int i=0; i<len; i++){
            char temp = strs[0].charAt(i);
            for(int j=1; j<strs.length; j++){
                if(temp != strs[j].charAt(i)){
                    return s;
                }
            }
            s += temp;
        }
        return s;
    }
}

四、时空复杂度分析 

        时间复杂度:        O(MN)        M是数组中字符串平均长度,N是数组长度。最坏情况需要遍历数组中所有字符串 

        空间复杂度:        O(1)

五、代码优化

        直接将s初始化为最短的字符串,然后逐一判断数组中所有的字符串是否以s开头。若不,那么将s更新为二者的共同前缀。

class Solution {
    public String longestCommonPrefix(String[] strs) {
        String s = strs[0];
        //令s为最短的字符串
        for(int i=0; i<strs.length; i++){
            if(strs[i].length() < s.length()){
                s = strs[i];
            }
        }

        for(int i=0; i<strs.length; i++){
            //判断第i个字符串的前缀是不是s,如果不是,取共同前缀
            if(!strs[i].startsWith(s)){ 
                s = sub(strs[i], s);
            }
        }
        return s;
    }

    //取两个字符串的共同前缀
    public static String sub(String a, String b){
        int len = Math.min(a.length(), b.length());
        int i;
        for(i=0; i<len; i++){
            if(a.charAt(i) != b.charAt(i)){
                break;
            }
        }
        return a.substring(0, i);
    }
}

        极大减少了运行时间,前面的方法在力扣中需要8ms,打败8%的提交

        这个方法只需0ms,打败100%的提交。 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/125048.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!