伍佰目录 短网址
  当前位置:海洋目录网 » 站长资讯 » 站长资讯 » 文章详细 订阅RssFeed

《剑指offer》第14天:最长公共前缀

来源:本站原创 浏览:47次 时间:2023-07-16

01、题目分析

首先还是看下题目:


题目14: 最长公共前缀


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


示例1:

输入: ["flower","flow","flight"]输出: "fl"

示例 2:

输入: ["dog","racecar","car"]输出: ""解释: 输入不存在公共前缀。

解释:

  • 输入不存在公共前缀。
    说明:

  • 所有输入只包含小写字母 a-z02、题解分析

我们要想寻找最长公共前缀,那么首先这个前缀是公共的,我们可以从任意一个元素中找到它。假定我们现在就从一个数组中寻找最长公共前缀,那么首先,我们可以将第一个元素设置为基准元素x0。假如数组为["flow","flower","flight"],flow就是我们的基准元素x0。

然后我们只需要依次将基准元素和后面的元素进行比较(假定后面的元素依次为x1,x2,x3....),不断更新基准元素,直到基准元素和所有元素都满足最长公共前缀的条件,就可以得到最长公共前缀。

具体比对过程如下:

  • 如果strings.Index(x1,x) == 0,则直接跳过(因为此时x就是x1的最长公共前缀),对比下一个元素。(如flower和flow进行比较)
  • 如果strings.Index(x1,x) != 0, 则截取掉基准元素x的最后一个元素,再次和x1进行比较,直至满足string.Index(x1,x) == 0,此时截取后的x为x和x1的最长公共前缀。(如flight和flow进行比较,依次截取出flow-flo-fl,直到fl被截取出,此时fl为flight和flow的最长公共前缀)
    具体过程如下图所示:

我们需要注意的是,在处理基准元素的过程中,如果基准元素和任一一个元素无法匹配,则说明不存在最长公共元素。

最后,我们记得处理一下临界条件。如果给定数组是空,也说明没有最长公共元素。

然后我们就可以开始写我们的代码了。

03、代码分析

题解可以很自然的给出,我们先给一个 go 的版本:

//GOfunc longestCommonPrefix(strs []string) string {    if len(strs) < 1 {        return ""    }    prefix := strs[0]    for _,k := range strs {        for strings.Index(k,prefix) != 0 {            if len(prefix) == 0 {                return ""            }            prefix = prefix[:len(prefix) - 1]        }    }    return prefix}

运行结果:

再给一个 java 语言的版本:

//JAVAclass Solution {    public String longestCommonPrefix(String[] strs) {        if (strs.length < 1 ) return "";        String prefix = strs[0];        for (String k : strs) {            while (k.indexOf(prefix) != 0) {                if (prefix.length() == 0) return "";                prefix = prefix.substring(0, prefix.length() - 1);            }        }        return prefix;    }}

运行结果:

  推荐站点

  • At-lib分类目录At-lib分类目录

    At-lib网站分类目录汇集全国所有高质量网站,是中国权威的中文网站分类目录,给站长提供免费网址目录提交收录和推荐最新最全的优秀网站大全是名站导航之家

    www.at-lib.cn
  • 中国链接目录中国链接目录

    中国链接目录简称链接目录,是收录优秀网站和淘宝网店的网站分类目录,为您提供优质的网址导航服务,也是网店进行收录推广,站长免费推广网站、加快百度收录、增加友情链接和网站外链的平台。

    www.cnlink.org
  • 35目录网35目录网

    35目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向35目录推荐、提交优秀网站。

    www.35mulu.com
  • 就要爱网站目录就要爱网站目录

    就要爱网站目录,按主题和类别列出网站。所有提交的网站都经过人工审查,确保质量和无垃圾邮件的结果。

    www.912219.com
  • 伍佰目录伍佰目录

    伍佰网站目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向伍佰目录推荐、提交优秀网站。

    www.wbwb.net