力扣(LeetCode) 14: 最长公共前缀 - 解法思路

问题概述

编写一个函数来查找字符串数组中的最长公共前缀。如果不存在公共前缀,返回空字符串 ""

解法 1:垂直扫描

工作原理

逐个位置比较所有字符串中相同位置的字符:

python 复制代码
class Solution:
    def longestCommonPrefix(self, strs):
        if not strs:
            return ""
        
        for i in range(len(strs[0])):
            char = strs[0][i]
            for string in strs[1:]:
                if i >= len(string) or string[i] != char:
                    return strs[0][:i]
        
        return strs[0]

复杂度分析

  • 时间复杂度: O(S) - 其中 S 是所有字符串中所有字符的总和
  • 空间复杂度: O(1) - 只使用常数额外空间

何时使用

  • 直观的逐字符比较
  • 发现不匹配时提前终止

解法 2:水平扫描(推荐)

工作原理

从第一个字符串开始作为前缀,然后与每个后续字符串比较,根据需要缩短前缀:

python 复制代码
class Solution:
    def longestCommonPrefix(self, strs):
        if not strs:
            return ""
        
        prefix = strs[0]
        for i in range(1, len(strs)):
            while not strs[i].startswith(prefix):
                prefix = prefix[:-1]
                if not prefix:
                    return ""
        
        return prefix

关键洞察

如果所有字符串的公共前缀是 P,那么任何字符串都必须以 P 开头。我们从第一个字符串开始作为候选前缀,然后通过删除最后一个字符来缩短它,直到它与每个后续字符串的开头匹配。

复杂度分析

  • 时间复杂度: O(S) - 其中 S 是所有字符串中所有字符的总和
  • 空间复杂度: O(1) - 只使用常数额外空间

何时使用

  • 推荐 - 在大多数情况下实际最快
  • 简单高效
  • 当前缀较短时效果很好

对比

方法 时间 空间 最佳适用
垂直扫描 O(S) O(1) 提前终止的情况
水平扫描 O(S) O(1) 大多数情况,最快

总结

水平扫描方法在大多数情况下实际最快。它简单、高效,在当前缀相对较短时效果很好。垂直扫描方法也很好,在某些情况下可能更早终止。

相关推荐
2301_818008445 分钟前
如何删除ASM中的数据文件_ALTER DISKGROUP DROP FILE彻底清除
jvm·数据库·python
AI玫瑰助手6 分钟前
Python基础:数据类型的转换(int/str/list等互转)
windows·python·list
Chat_zhanggong3459 分钟前
主推NT98336BG作用有哪些?
嵌入式硬件·算法
深度学习lover14 分钟前
<数据集>yolo 常见对象检测<目标检测>
人工智能·python·yolo·目标检测·计算机视觉·常见对象检测
财经资讯数据_灵砚智能15 分钟前
基于全球经济类多源新闻的NLP情感分析与数据可视化(夜间-次晨)2026年4月27日
人工智能·python·信息可视化·自然语言处理·ai编程
2401_8987176619 分钟前
mysql如何进行全量数据库备份_mysqldump工具的使用技巧
jvm·数据库·python
wangbing112523 分钟前
Java处理csv文件总是丢数据
java·开发语言·python
qq_2837200524 分钟前
高并发场景下 Python+MySQL 性能优化最佳实践
python·mysql·性能优化
m0_7485548124 分钟前
SQL注入的安全架构设计_将数据库置于内网隔离区
jvm·数据库·python
Run_Teenage29 分钟前
算法:线段树
算法