leetcode5 最长公共前缀三种python解法

  1. 最长公共前缀

编写一个函数来查找字符串数组中的最长公共前缀。

如果不存在公共前缀,返回空字符串 ""

示例 1:

复制代码
输入:strs = ["flower","flow","flight"]
输出:"fl"

示例 2:

复制代码
输入:strs = ["dog","racecar","car"]
输出:""
解释:输入不存在公共前缀。

一开始觉得难的地方是在字符串数组里循环字符串,然后再挨个比较字符串里面的字母是否相同,后来find函数------检测字符串中是否包含子字符串 str

复制代码
str1.find(str, beg=0, end=len(string))

返回值,默认是0,如果没找到返回-1;因此只要选择list中任意一个字符串作为子字符串,循环检索list每个字符串(比较要注意,比较如果没有就让子字符串从后面-1,此时不去检索下一个,而是一直循环在这个字符串上,接着find直至找到相同的部分,因为是公共的必须满足每一个都找到相同的)

法一:

python 复制代码
class Solution:
    def longestCommonPrefix(self, strs: List[str]) -> str:
        if not strs:
            return ""
        res=strs[0]#先res=第一个字符串
        for i in range(1,len(strs)):
            while strs[i].find(res)!=0:
                res=res[0:len(res)-1]#如果没找到就减一个
            i+=1
        return res

法二:字符串sort后 字典中以最小和最大的相同位置字符进行比较,循环终止条件是遇到不想等的字符或者是到达某一个字符串的末尾

python 复制代码
class Solution:
    def longestCommonPrefix(self, strs: List[str]) -> str:
        if not strs:
            return ""
        strs.sort()
        first=strs[0]
        last=strs[-1]
        res=""
        length=len(first)
        for i in range(length):
            if i<length and first[i]==last[i]:
                res+=first[i]
            else:
                break
            
        return res
  • 字符串相加是字符串
  • else:break必须,因为是从前向后检索,有不相同那么后面所有都不相同就不用for往后循环了

法三:python的zip函数将列表(对象)打包为元组,按列组合+enumerate在回文数中用于遍历列表(或者元组、字符串)的下标和元素

python 复制代码
class Solution:
    def longestCommonPrefix(self, strs: List[str]) -> str:
        if not strs:
            return ""
        for i, str in enumerate(zip(*strs)):
            if len(set(str))>1:#str为字符串按列组合------下标相同;set是组成集合,过滤重复元素;如果=1是都相同,如果>1则对应相同下表的字符不相同
                return strs[0][0:i]
        return min(strs)

*strs使用解包操作符,把strs元素拆分册灰姑娘多个单独的参数,zip把相同位置的字符打包成元组,for中如果有字符不相同就返回strs中任意一个字符串的前i-1个元素;如果没有就返回长度最小的一定是公共的

相关推荐
你怎么知道我是队长几秒前
C语言---排序算法4---希尔排序法
c语言·算法·排序算法
Tony Bai1 分钟前
【分布式系统】11 理论的试金石:用 Go 从零实现一个迷你 Raft 共识
开发语言·后端·golang
机 _ 长1 分钟前
YOLO26 改进 | 训练策略 | 知识蒸馏 (Response + Feature + Relation)
python·深度学习·yolo·目标检测·机器学习·计算机视觉
Beginner x_u1 分钟前
JavaScript 原型、原型链与原型继承的核心机制解析
开发语言·javascript·原型模式·原型原型链
离离茶1 分钟前
【笔记1-11】Qt 关闭QToolbar的拓展菜单
开发语言·笔记·qt
曹牧3 分钟前
C#:窗体构造函数无法引用窗体控件
开发语言·c#
草青工作室5 分钟前
java-FreeMarker3.4自定义异常处理
java·前端·python
iAkuya6 分钟前
(leetcode)力扣100 54实现Trie树
算法·leetcode·c#
xb11327 分钟前
C#使用Cancellation来取消异步任务
开发语言·c#
m0_748229998 分钟前
C与C#:编程语言的核心差异解析
c语言·开发语言·c#