题目描述
编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 “”。
输入: ["flower","flow","flight"]
输出: "fl"
输入: ["dog","racecar","car"]
输出: ""
解释: 输入不存在公共前缀。
解法一:垂直扫描法
依次判断所有字符串的每一列是否相同。
class Solution:
def longestCommonPrefix(self, strs: List[str]) -> str:
if len(strs) == 0:
return ''
for i in range(len(strs[0])):# i遍历一个字符串的每个字母
c = strs[0][i]
for j in range(1,len(strs)): #j的范围是[1,len(strs)-1]
# 若遍历完某字符串,则应结束,且 or 前后的条件不能写反
if i == len(strs[j]) or strs[j][i] != c:
return strs[0][0:i]
return strs[0]
解法二:Python的 zip 函数
取每一个单词的同一位置的字母,看是否相同。
>>> a = [1,2,3]
>>> b = [4,5,6]
>>> c = [4,5,6,7,8]
>>> zipped = zip(a,b) # 打包为元组的列表
[(1, 4), (2, 5), (3, 6)]
下面是与本题相关的例子
>>> a = ["abc", "abd", "bbb"]
>>> b = zip(a)
>>> for each in b:
... print(each)
...
('abc',)
('abd',)
('bbb',)
如果各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同,利用 * 号操作符,可以将元组解压为列表
>>> b = zip(*a)
>>> for each in b:
... print(each)
...
('a', 'a', 'b')
('b', 'b', 'b')
('c', 'd', 'b')
class Solution:
def longestCommonPrefix(self, strs: List[str]) -> str:
res = ""
for tmp in zip(*strs):
#print(tmp)
tmp_set = set(tmp)
if len(tmp_set) == 1:
res += tmp[0]
else:
break
return res
解法三:Python 一行
class Solution:
def longestCommonPrefix(self, strs: List[str]) -> str:
return os.path.commonprefix(strs)