X

LEETCODE 14. Longest Common Prefix 解题思路分析

题目大意:

最长公共前缀

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

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

示例 1:

输入: ["flower","flow","flight"]
输出: "fl"

示例 2:

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

说明:

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


如果想查看本题目是哪家公司的面试题,请参考以下免费链接: https://leetcode.jp/problemdetail.php?id=14

解题思路分析:

本体使用暴力解即可。从第一位开始比较每个字符串上该位置的字符,如果存在不同或者当前位超过某个字符串长度范围,结束循环。返回之前的子串即可。

实现代码:

public String longestCommonPrefix(String[] strs) {
    if(strs.length==0) return "";
    StringBuilder sb=new StringBuilder();
    int index=0;
    while(true){
        if(index==strs[0].length()) return sb.toString();
        char c = strs[0].charAt(index);
        for(int i=1;i<strs.length;i++){
            if(index==strs[i].length()) return sb.toString();
            if(strs[i].charAt(index)!=c) return sb.toString();
        }
        sb.append(c);
        index++;
    }
}

本题解法执行时间为0ms。

Runtime: 0 ms, faster than 100.00% of Java online submissions for Longest Common Prefix.

Memory Usage: 37.4 MB, less than 95.32% of Java online submissions for Longest Common Prefix.

本网站文章均为原创内容,并可随意转载,但请标明本文链接
如有任何疑问可在文章底部留言。为了防止恶意评论,本博客现已开启留言审核功能。但是博主会在后台第一时间看到您的留言,并会在第一时间对您的留言进行回复!欢迎交流!
本文链接: http://leetcode.jp/leetcode-14-longest-common-prefix-解题思路分析/
Categories: leetcode
kwantong: