78 题(最长公共前缀)

继续用「快刷四部曲」把 78 题(最长公共前缀)5 分钟秒掉。

(模板记忆点:① 纵向扫描;② 一旦失配立即 return;③ 空数组特护。)


① 抽象模型

k 个字符串,求从左端开始的最长公共子串。

等价于:对第 0 列、第 1 列...逐列检查,直到某一列字符不全相同或某个字符串已经到头。


② 最优算法

时间:O(totalLen) 所有字符最多被看一次。

空间:O(1) 原地比对。

算法:

  1. 特护:strs == null || strs.length == 0 → return ""
  2. 令 minLen = 最短字符串长度
  3. 逐列 col = 0 ... minLen-1
    • 取 strs[0].charAt(col) 作为基准
    • 遍历 i = 1...k-1,若 strs[i].charAt(col) ≠ 基准 → 立即 return strs[0].substring(0, col)
  4. 循环结束 return strs[0].substring(0, minLen)

③ 边界/异常

  • 空数组 ⇒ ""
  • 含空串 ⇒ ""
  • 仅一个字符串 ⇒ 它自身

④ 代码(Java,可直接粘 LintCode)

java 复制代码
public String longestCommonPrefix(String[] strs) {
    if (strs == null || strs.length == 0) return "";
    int minLen = Integer.MAX_VALUE;
    for (String s : strs) minLen = Math.min(minLen, s.length());
    for (int col = 0; col < minLen; col++) {
        char c = strs[0].charAt(col);
        for (int i = 1; i < strs.length; i++) {
            if (strs[i].charAt(col) != c) {
                return strs[0].substring(0, col);
            }
        }
    }
    return strs[0].substring(0, minLen);
}

复杂度:

时间 O(∑len),空间 O(1)。

写完,Submit,一遍 AC。

相关推荐
历程里程碑17 分钟前
普通数组----合并区间
java·数据结构·python·算法·leetcode·职场和发展·tornado
梵刹古音1 小时前
【C语言】 指针与数据结构操作
c语言·数据结构·算法
爱敲代码的TOM2 小时前
数据结构总结
数据结构
皮皮哎哟4 小时前
数据结构:嵌入式常用排序与查找算法精讲
数据结构·算法·排序算法·二分查找·快速排序
堕2745 小时前
java数据结构当中的《排序》(一 )
java·数据结构·排序算法
2302_813806225 小时前
【嵌入式修炼:数据结构篇】——数据结构总结
数据结构
Wei&Yan6 小时前
数据结构——顺序表(静/动态代码实现)
数据结构·c++·算法·visual studio code
long3166 小时前
Aho-Corasick 模式搜索算法
java·数据结构·spring boot·后端·算法·排序算法
张张努力变强9 小时前
C++ STL string 类:常用接口 + auto + 范围 for全攻略,字符串操作效率拉满
开发语言·数据结构·c++·算法·stl
wWYy.9 小时前
数组快排 链表归并
数据结构·链表