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。

相关推荐
Pluchon4 分钟前
硅基计划4.0 算法 优先级队列
数据结构·算法·排序算法
漫随流水20 分钟前
leetcode算法(257.二叉树的所有路径)
数据结构·算法·leetcode·二叉树
Renhao-Wan36 分钟前
数据结构在Java后端开发与架构设计中的实战应用
java·开发语言·数据结构
Yupureki1 小时前
《算法竞赛从入门到国奖》算法基础:入门篇-贪心算法(上)
c语言·数据结构·c++·算法·贪心算法·visual studio
散峰而望1 小时前
【算法竞赛】队列和 queue
开发语言·数据结构·c++·算法·链表·github·线性回归
yuanmenghao1 小时前
车载Linux 系统问题定位方法论与实战系列 - 开篇: 为什么需要一套“系统化”的 Linux 问题定位方法
linux·运维·服务器·数据结构·c++·自动驾驶
CodeByV1 小时前
【算法题】字符串
数据结构·算法
yuanmenghao2 小时前
车载Linux 系统问题定位方法论与实战系列 - 系统 reset / reboot 问题定位
linux·服务器·数据结构·c++·自动驾驶
楼田莉子2 小时前
C++高级数据结构——LRU Cache
数据结构·c++·后端·学习
闻缺陷则喜何志丹2 小时前
P10160 [DTCPC 2024] Ultra|普及+
数据结构·c++··洛谷