首页 > 其他 > 详细

Longest Common Prefix

时间:2014-10-18 22:15:46      阅读:260      评论:0      收藏:0      [点我收藏+]

Write a function to find the longest common prefix string amongst an array of strings.

分析:

对一组字符串找到最长公共前缀。

因为只是找前缀所以可以以第一个字符串为基础,按个字符与其它字符串比较,直到有字符串已经遍历完或者碰到不一致的字符,返回到当前为止第一个字符串的前缀即可。

class Solution:

    # @return a string
    def longestCommonPrefix(self, strs):
        if not strs or not strs[0]:
            return ""

        first = strs[0]
        for i in range(len(first)):
            for s in strs[1:]:
                if i >= len(s) or s[i] != first[i]:
                    return first[:i]
        return first

if __name__ == __main__:
    s = Solution()
    assert s.longestCommonPrefix([]) == ""
    assert s.longestCommonPrefix([""]) == ""
    assert s.longestCommonPrefix(["a", "b"]) == ""
    assert s.longestCommonPrefix(["aa", "aa"]) == "aa"
    print PASS

小结:

这个问题比较简单,也没有太多程序编写上的陷阱,按直觉解法写出代码就可以Accepted。

Longest Common Prefix

原文:http://www.cnblogs.com/openqt/p/4033672.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!