python(leetcode)-14最长公共前缀

时间:2023-12-12 09:01:50
编写一个函数来查找字符串数组中的最长公共前缀。

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

示例 1:

输入: ["flower","flow","flight"]
输出: "fl"
示例 2: 输入: ["dog","racecar","car"]
输出: ""
解释: 输入不存在公共前缀。
说明: 所有输入只包含小写字母 a-z 。

 这题比较好理解,给定一个列表,查询列表中的公共前缀

自己的想法是直接暴力法解决,将列表的第一个值作为对比值,通过一层for循环不断遍历对比值与其他元素是否相等,如果相等则继续对比,如果不等return比较过的值。

上代码(40ms)击败12%用户

 class Solution(object):
def longestCommonPrefix(self, strs):
"""
:type strs: List[str]
:rtype: str
"""
sig=True
i=0
if(strs==[] ): #判断是否为空
return ""
if(len(strs)==1): #判断是否只有一个值
return strs[0]
if ("" in strs): #判断有没有空值
return ""
while(sig==True ): #sig是一个bool类型值 True继续判断 False中断返回
if(len(strs[0])<=i): #判断对比值是否越界
return strs[0][0:i]
temp=strs[0][i] #第i个字符
for j in strs[1:]:
if(temp!=j[i] ): #如果第i字符不匹配 则返回前i-1个字符
return strs[0][0:i]
elif(temp==j[i] and len(j)==i+1): #如果第i字符为最后一个一字母,则不继续对比,返回前i个
sig=False
k=i
i += 1
return strs[0][0:k+1]
if __name__=="__main__":
s=Solution()
li=["flower","flo","flight"]
print(s.longestCommonPrefix(li))

看了评论区大佬的代码,觉得有一个想法特别好

上代码(28ms)击败94%

 class Solution(object):
def longestCommonPrefix(self, strs):
"""
:type strs: List[str]
:rtype: str
"""
if not strs: return ""
if len(strs) == 1: return strs[0] strs.sort()
p = ''
for x, y in zip(strs[0], strs[-1]):
if x == y:
p += x
else:
break
return p
if __name__=="__main__":
s=Solution()
li=["flower","fl","flight"]
print(s.longestCommonPrefix(li))

解释一下:

前两句没啥好说的,判断特殊情况

然后进行排序,直接将第一个元素和最后一个元素对比,提取出相同字符。

特点:排序后的列表,不需要对比中间的元素 直接对比最后两个即可。