力扣(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) 大多数情况,最快

总结

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

相关推荐
涛声依旧-底层原理研究所8 小时前
残差连接与层归一化通俗易懂的详解
人工智能·python·神经网络·transformer
csdn_aspnet8 小时前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展
fantasy_arch8 小时前
pytorch人脸匹配模型
人工智能·pytorch·python
熊猫_豆豆8 小时前
广义相对论水星近日点进动完整详细数学推导
python·天体·广义相对论
web3.08889999 小时前
1688 图搜接口(item_search_img / 拍立淘) 接入方法
开发语言·python
AI算法沐枫9 小时前
深度学习python代码处理科研测序数据
数据结构·人工智能·python·深度学习·决策树·机器学习·线性回归
一只机电自动化菜鸟10 小时前
一建机电备考笔记(40) 建筑机电施工—排水管道施工(含考频+题型)
经验分享·笔记·学习·职场和发展·课程设计
X1A0RAN10 小时前
解决Pycharm中部分文件或文件夹被隐藏不展示问题
ide·python·pycharm
kyriewen10 小时前
面试官让我查各部门工资最高的员工,我用AI三秒写出窗口函数,他愣了
后端·mysql·面试