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。

相关推荐
‎ദ്ദിᵔ.˛.ᵔ₎18 小时前
LIST 的相关知识
数据结构·list
M--Y18 小时前
Redis常用数据类型
数据结构·数据库·redis
༾冬瓜大侠༿19 小时前
vector
c语言·开发语言·数据结构·c++·算法
汀、人工智能19 小时前
[特殊字符] 第58课:两个正序数组的中位数
数据结构·算法·数据库架构··数据流·两个正序数组的中位数
liu****19 小时前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
汀、人工智能19 小时前
[特殊字符] 第79课:分割等和子集
数据结构·算法·数据库架构·位运算·哈希表·分割等和子集
汀、人工智能20 小时前
[特殊字符] 第74课:完全平方数
数据结构·算法·数据库架构·图论·bfs·完全平方数
CoderCodingNo20 小时前
【GESP】C++四、五级练习题 luogu-P1177 【模板】排序
数据结构·c++·算法
汀、人工智能20 小时前
[特殊字符] 第76课:单词拆分
数据结构·算法·均值算法·前缀树·trie·单词拆分
ambition2024221 小时前
斐波那契取模问题的深入分析:为什么提前取模是关键的
c语言·数据结构·c++·算法·图论