Longest Common Prefix

题目:给定一个String类型数组,要求写一个方法,返回数组中这些字符串的最长公共前缀。举个例子:假如数组为[“123”,”12”,”4”],经过这个方法返回的结果就应该是”“。因为”123”,”12”,”4”并没有共同的前缀,虽然”123”,”12”的公共最长前缀是”12”,但是这个公共前缀”12”与”4”没有公共前缀,所以最后返回的结果就是”“。

第一想法肯定是将str[0],当作临时最长公共前缀,然后用这个前缀依次和剩下的字符串进行前缀比较,都比较完后,就将最后得到的最新公共最长前缀返回。但是这要多加一个循环判断长度,或者一个一个比,好恶心~所以我在判断数组不为空之后,首先就做一个字符串数组排序,这样只需要判断第一个和最后一个是否有公共的前缀,太爽了~



class Solution:

    def longestCommonPrefix(self, strs):
        """
        :type strs: List[str]
        :rtype: str
        """
        #判断字符串列表是否为空,如果为空,则输出""
        if len(strs) == 0:
            return ""
        else:
            strs2 = sorted(strs) #对数组排序
            length = len(strs2)
            l1 = strs2[0]
            l2 = strs2[length-1]

            prefix = l1
            for i in range(len(l1)):
                if l1[i] != l2[i]:
                    prefix = prefix[0:i]
                    break
            return prefix

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值