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。

相关推荐
一个爱编程的人2 小时前
一个数是不是素数
数据结构·算法
忡黑梨3 小时前
eNSP_从直连到BGP全网互通
c语言·网络·数据结构·python·算法·网络安全
地球资源数据云4 小时前
1900-2023年中国物种分布点位矢量数据集
大数据·数据结构·数据库·数据仓库·人工智能
AI人工智能+电脑小能手4 小时前
【大白话说Java面试题】【Java基础篇】第20题:HashMap在计算index的时候,为什么要对数组长度做减1操作
java·开发语言·数据结构·后端·面试·哈希算法·hash-index
牢姐与蒯4 小时前
cpp数据结构之map
数据结构
故事和你914 小时前
洛谷-算法2-3-分治与倍增5
开发语言·数据结构·c++·算法·动态规划·图论
北顾笙9805 小时前
day37-数据结构力扣
数据结构·算法·leetcode
liuyao_xianhui6 小时前
进程概念与进程状态_Linux
linux·运维·服务器·数据结构·c++·哈希算法·宽度优先
如君愿6 小时前
考研复习 Day 26 | 习题--计算机网络第三章(数据链路层 下)、数据结构 多维数组与广义表
数据结构·计算机网络·考研·记录考研
bqq198610266 小时前
MySQL分库分表
数据结构·mysql