Leetcode14 最长公共前缀 垂直扫描法 python的zip函数妙用 一个代码

题目描述

编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 “”。

输入: ["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)

你可能感兴趣的:(leetcode)