编写一个函数来查找字符串数组中的最长公共前缀。

如果不存在公共前缀,返回空字符串 ""。

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

首先理解题意:

  • 当源字符串数组中一个元素也没有,那肯定是返回空字符串了

        slen := len(strs)
    //特殊情况,当切片中没有任何元素的时候返回""
    if slen=={
    return ""
    }
  • 而最坏的情况就是得到源数组中长度最小的字符串,那我们就要找到最小长度的字符串了
    //找出最小长度的字符串、字符串长度以及索引
minLen := math.MaxInt32
minIndex :=
minLenStr := ""
for i := ; i < slen; i++ {
if len(strs[i]) < minLen {
minLen = len(strs[i])
minIndex = i
minLenStr = strs[i]
}
}
  • 然后我们就可以对源字符串中的每一个元素与最小长度的那个字符串比较了,但是考虑到空间和时间的问题,我们可以先把源字符串中的那个最小长度的字符串去掉,然后再进行比较

        //先对上面得到的最小长度的字符串进行for循环,得到每一个字符
    //然后对源切片strs剩下的元素进行for循环,得到strs中每个元素的第一位字符,与最小长度得到的字符相比
    //最后把相同的字符加到返回值中去
    for _, c := range minLenStr {
    for z := ; z < len(strs); z++ {
    if string(c) == string(strs[z][]) {
    strs[z] = strs[z][:]
    } else {
    return result
    }
    }
    result += string(c)
    }
    return result

    这里有个小技巧,就是每次只比对源字符串数组剩下的元素的第一位,如果是与最小字符串对应位置的一样,那我们就把源字符串数组对应的元素去除掉第一个字符

    整体代码:
    func longestCommonPrefix(strs []string) string {
    result := ""
    slen := len(strs)
    //特殊情况,当切片中没有任何元素的时候返回""
    if slen=={
    return ""
    } //找出最小长度的字符串、字符串长度以及索引
    minLen := math.MaxInt32
    minIndex :=
    minLenStr := ""
    for i := ; i < slen; i++ {
    if len(strs[i]) < minLen {
    minLen = len(strs[i])
    minIndex = i
    minLenStr = strs[i]
    }
    } //在strs去除掉长度最小的字符串
    strs = append(strs[:minIndex], strs[minIndex+:]...) //先对上面得到的最小长度的字符串进行for循环,得到每一个字符
    //然后对源切片strs剩下的元素进行for循环,得到strs中每个元素的第一位字符,与最小长度得到的字符相比
    //最后把相同的字符加到返回值中去
    for _, c := range minLenStr {
    for z := ; z < len(strs); z++ {
    if string(c) == string(strs[z][]) {
    strs[z] = strs[z][:]
    } else {
    return result
    }
    }
    result += string(c)
    }
    return result
    }

    当然我们也有另外一种思考方式,那就是比较不一样的,当不一样,那我们就返回源切片的对应元素的对应索引,不然就直接返回最小长度的字符串

        for i, c := range minLenStr {
    for z := ; z < len(strs); z++ {
    if strs[z][i] != byte(c) {
    return strs[z][:i]
    }
    }
    }
    return minLenStr

最长公共前缀的golang实现的更多相关文章

  1. [转][LeetCode]Longest Common Prefix ——求字符串的最长公共前缀

    题记: 这道题不难但是很有意思,有两种解题思路,可以说一种是横向扫描,一种是纵向扫描. 横向扫描:遍历所有字符串,每次跟当前得出的最长公共前缀串进行对比,不断修正,最后得出最长公共前缀串. 纵向扫描: ...

  2. lintcode :最长公共前缀

    题目 最长公共前缀 给k个字符串,求出他们的最长公共前缀(LCP) 样例 在 "ABCD" "ABEF" 和 "ACEF" 中,  LCP ...

  3. LeetCode Longest Common Prefix 最长公共前缀

    题意:给多个字符串,返回这些字符串的最长公共前缀. 思路:直接逐个统计同一个位置上的字符有多少种,如果只有1种,那么就是该位是相同的,进入下一位比较.否则终止比较,返回前缀.可能有一个字符串会比较短, ...

  4. 扩展KMP--求字符串S的所有后缀和字符串T的最长公共前缀

    在解上面这个问题前我们要先解决一个类似的问题:求字符串s的所有后缀和s本身的最长公共前缀: 我们用next[]数组保存这些值: 现在我们假设要求next[ x ],并且next[ i ] 0<i ...

  5. BNUOJ34990--Justice String (exkmp求最长公共前缀)

    Justice String Given two strings A and B, your task is to find a substring of A called justice strin ...

  6. [Swift]LeetCode14. 最长公共前缀 | Longest Common Prefix

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

  7. [LeeCode]14. 最长公共前缀

    题目链接:https://leetcode-cn.com/problems/longest-common-prefix/ 题目描述: 编写一个函数来查找字符串数组中的最长公共前缀. 如果不存在公共前缀 ...

  8. python(leetcode)-14最长公共前缀

    编写一个函数来查找字符串数组中的最长公共前缀. 如果不存在公共前缀,返回空字符串 "". 示例 1: 输入: ["flower","flow" ...

  9. leetcode-14最长公共前缀

    leetcode-14最长公共前缀 题目 编写一个函数来查找字符串数组中的最长公共前缀. 如果不存在公共前缀,返回空字符串 "". 示例 1: 输入: ["flower& ...

随机推荐

  1. shiro教程3(加密)

    加密,是以某种特殊的算法改变原有的信息数据,使得未授权的用户即使获得了已加密的信息,但因不知解密的方法,仍然无法了解信息的内容 概念 数据加密的基本过程就是对原来为明文的文件或数据按某种算法进行处理, ...

  2. 微信小程序 - 入门指引

    稍微整了整微信小程序,还是有不少问题的,做个小总结吧 和以往一样,本次项目也放到了 Github 中,欢迎围观 star ~ 一.微信公众平台 - 小程序后台 1.申请小程序账号 官网注册 注册时所用 ...

  3. python装饰器带括号和不带括号的语法和用法

    装饰器的写法补充: 通常装饰器的写法是@func(),而有的时候为了减少出错率,可能会写成@func,没有()括号,这时我们可以这样定义,来减少括号.下面通过两个例子还看. 一般装饰器的写法: def ...

  4. SpringBoot JPA + H2增删改查示例

    下面的例子是基于SpringBoot JPA以及H2数据库来实现的,下面就开始搭建项目吧. 首先看下项目的整体结构: 具体操作步骤: 打开IDEA,创建一个新的Spring Initializr项目, ...

  5. 原生js格式化json工具

    json格式化小工具,原生js编写,直接上代码: <!DOCTYPE html> <html lang="en"> <head> <met ...

  6. openssl passwd

    openssl系列文章:http://www.cnblogs.com/f-ck-need-u/p/7048359.html 该伪命令用于生成加密的密码. [root@xuexi tmp]# whati ...

  7. 玩转物联网之MQTT

    物联网概述 物联网——即Internet-of-Things,其实这个概念由来已久,简单来讲,物联网是物与物.人与物之间的信息传递与控制简称.它和能源.电子信息.医疗.交通.零售.物流.工业制造等行业 ...

  8. 通向全栈之路(6)—无密码ssh连接

    (1)在用户目录下新增一个 .ssh文件 mkdir .ssh (2)生成公钥.私钥 ssh-keygen -t rsa -b 4096 -C "mail@xxx.com" (3) ...

  9. 在EF中执行SQL语句(转载)

    在EF中执行SQL语句   你可能要问,我用EF不就为了避免写SQL吗?如果要写SQL我不如直接用ADO.NET得了.话虽然这么说没错,可有些时候使用EF操作数据还是有一些不方便,例如让你根据条件删除 ...

  10. java基础之XML

    目录 java基础之XML 1. XML解析概述 2. DOM4J介绍 2.1 常用包 2.2 内置元素 2.2 Element类 2.3 Attribute类 2.4 常用操作 3. 代码演示 3. ...