LeetCode第14题最长公共前缀

继续打卡算法题,今天学习的是LeetCode的第14题最长公共前缀,这道题目是道简单题。算法题的一些解题思路和技巧真的非常巧妙,每天看一看算法题和解题思路,我相信对我们的编码思维和编码能力有一些帮助。

分析一波题目

这个题目最容易想到就是取一个字符串串作为基准,然后一列一列字符比较,如果字符都相同记录下标,如果遇到长度不一致或者串的某列字符不匹配就结束。

比如["ab","abc","abcd"] ,用第一个字符串做基准,先比较第一列a,再比较第二列b,第一个字符串没有第三列了,那么最长公共前缀就是"ab"。

编码实现

java 复制代码
class Solution {
    public String longestCommonPrefix(String[] strs) {
        if(strs.length == 1) {
            return strs[0];
        }
        //取第一子串
        String s = strs[0];
        int start=0;
        //遍历所有子串
        for(int i=0; i<s.length(); i++) {
            boolean eq = true;
            //循环第一个子串长度
            for(int j=1; j< strs.length; j++) {
                String s1 = strs[j];
                //长度判断是否匹配
                if(s1.length() < i+1) {
                    eq = false;
                    break;
                } else if(s.substring(i,i+1).equals(s1.substring(i,i+1)) == false) {
                    eq=false;
                    break;
                }
            }
            if(eq) {
                    start++;
                } else {
                    return s.substring(0,start);
                }
        }
        return s.substring(0,start);
        
    }
}

总结

这个题目的思路时间复杂度是O(m*n), m是第一个字符串的长度,第二个是字符串数组的长度。写法是比较简单的,如果使用二分查找法解决,代码复杂度会上升。

相关推荐
追随者永远是胜利者几秒前
(LeetCode-Hot100)301. 删除无效的括号
java·算法·leetcode·职场和发展·go
追随者永远是胜利者5 分钟前
(LeetCode-Hot100)239. 滑动窗口最大值
java·算法·leetcode·职场和发展·go
im_AMBER8 分钟前
Leetcode 126 两数之和 II - 输入有序数组 | 盛最多水的容器
数据结构·学习·算法·leetcode
lxl130718 分钟前
C++算法(5)位运算
java·c++·算法
tankeven18 分钟前
HJ96 表示数字
c++·算法
嵌入式×边缘AI:打怪升级日志21 分钟前
C语言算术赋值运算复习笔记
c语言·stm32·单片机·算法·51单片机·proteus·代码
lxl130724 分钟前
C++算法(4)前缀和
开发语言·c++·算法
不想看见40434 分钟前
Minimum Path Sum 基本动态规划:二维--力扣101算法题解笔记
算法·leetcode·动态规划
啊阿狸不会拉杆34 分钟前
《计算机视觉:模型、学习和推理》第 7 章-复杂数据密度建模
人工智能·python·学习·算法·计算机视觉·t分布·复杂数据密度建模
NEXT0639 分钟前
深拷贝与浅拷贝的区别
前端·javascript·面试