LeetCode热题100-最长公共前缀

这个题不是官网上热题100范围,因为这题也经常考所以放到这里。

这个其实思路相对固定,就是假设第1个元素为最长公共前缀,因此和其他元素比较得出最长公共前缀。

python 复制代码
class Solution:
    def longestCommonPrefix(self, strs: List[str]) -> str:
        if not strs:
            return ""
        
        first_str = strs[0]

        for i in range(len(first_str)):
            for j in range(1,len(strs)):
                if first_str[i] != strs[j][i]:
                    return first_str[0:i]
        
        return first_str
        

上面存在一个bug是strs[j][i]可能存在数组越界风险,官方可以的测试用例比较简单,所以没出现报错,可看下面的代码。

python 复制代码
class Solution:
    def longestCommonPrefix(self, strs: List[str]) -> str:
        if not strs:
            return ""
        
        for i in range(len(strs[0])):
            ch = strs[0][i]
            for s in strs[1:]:
                if i < len(s) and ch != s[i]:
                    return strs[0][:i]
        return strs[0]
python 复制代码
class Solution:
    def longestCommonPrefix(self, strs: List[str]) -> str:
        if not strs:
            return ""
        
        prefix = strs[0]

        for s in strs[1:]:
            while not s.startswith(prefix):
                prefix = prefix[:-1]
                if not prefix:
                    return ""
        return prefix
相关推荐
郝学胜-神的一滴2 小时前
PyTorch自动微分核心解析:从原理到实战实现权重更新
人工智能·pytorch·python·深度学习·算法·机器学习
会编程的土豆2 小时前
【数据结构与算法】 拓扑排序
数据结构·c++·算法
zth4130213 小时前
SegmentSplay‘s Super STL(v2.2)
开发语言·c++·算法
数据知道3 小时前
claw-code 源码详细分析:Bootstrap Graph——启动阶段图式化之后,排障与扩展为什么会变简单?
前端·算法·ai·bootstrap·claude code·claw code
Kel3 小时前
从Prompt到Response:大模型推理端到端核心链路深度拆解
人工智能·算法·架构
Felven3 小时前
D. Matryoshkas
算法
17(无规则自律)3 小时前
DFS连通域统计:岛屿数量问题及其变形
c++·算法·深度优先
白眼黑刺猬3 小时前
实时库存预警: 如何实现秒级更新且保证在高并发下不出现“超卖”显示错误?
大数据·面试·职场和发展
笨笨饿3 小时前
34_数据结构_栈
c语言·开发语言·数据结构·人工智能·嵌入式硬件·算法