Longest Common Prefix

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

求字符串数组中字符串的最长公共前缀。

Solutions

  • 1 Longest Common Prefix -- 11~13ms

    • 第一个映入大脑的是对每一个字符串,按字符位逐个比较,直到发现不相同的或者是有个字符串已经比较完了时,说明最大公共前缀已经找到。则时间复杂度是: \(O(MN)\) 其中 M 是字符数组的个数,N 是字符数组中最短字符串的长度。按这种思想的代码如下:
    class Solution {
    public:
    string longestCommonPrefix(vector<string> &strs) {
    if(strs.size()<=0)return string();
    int idx=0;
    string res;
    char c;
    string s=strs.at(0); //以第一个字串作为比较的基
    int n=s.size(),ns=strs.size();
    while(idx<n){
    c=strs.at(0).at(idx); //获取一个字符
    for(int i=0;i<ns;++i){ //循环和其他字串中对应位的字符进行比较
    s=strs.at(i);
    if(idx<s.size())
    if(s.at(idx)==c)continue;
    idx=n; //如果出现不相等或有字符串已结束,则退出循环
    break;
    }
    if(idx<n){
    res.push_back(c);
    }
    ++idx;
    }
    return res;
    }
    };
    • 分析了一下,这里占用时间的有两个:

      1. 每一次迭代时的字符串拷贝;
      2. 如果最短的字符串在最后一个比较或靠后比较,则就白白浪费了太多比较了,特别是字符串数组很大的时候。
    • 所以对方案 1 进行了改进,有了下面的方案 2 。
  • 2 Longest Common Prefix -- 8ms

    • 这种方案首先找到字串数组中最短的那个,并记录下其在字符数组中的下标,不进行拷贝,减少空间复杂度,同时,节省一点时间。
    • 其次,去除掉所有的字符串拷贝操作,除用于在大字符串数组情况下的优化时需要的变量外,尽量减少空间使用。可以看到,运行时间一下子减到了 8ms。说明还是有效果的。
    • 代码如下:
    class Solution {
    public:
    string longestCommonPrefix(vector<string> &strs) {
    if(strs.size()<=0)return string();
    int idx=0,base=0;
    string res;
    int ns=strs.size();
    while(idx<ns){
    if(strs.at(idx).size()<strs.at(base).size())
    base=idx;
    ++idx;
    }
    idx=0;
    char c;
    int n=strs.at(base).size();
    while(idx<n){
    c=strs.at(base).at(idx);
    for(int i=0;i<ns;++i){
    if(idx<strs.at(i).size())
    if(strs.at(i).at(idx)==c)continue;
    idx=n;
    break;
    }
    if(idx<n){
    res.push_back(c);
    }
    ++idx;
    }
    return res;
    }
    };
  • 3 Longest Common Prefix -- 8ms

    • 查阅了网友的解答,发现这样一种思路:
    • 以第一个字串为比较基的长度判定,逐位判断,如果发现有一个字串的长度小于或等于当前位,说明这个字串结束了,自然也应该结束函数;
    • 如果没有结束,逐位判断的方式使用:判断当前字串的当前位和下一个字串的当前位比较是否相同,不相同则结束。可以看到,效率还是很高的。
    class Solution {
    public:
    string longestCommonPrefix(vector<string> &strs) {
    if (strs.size() == 0) return "";
    string s;
    for (int i = 0; i < strs[0].length(); i++) {
    for (int j = 0; j < strs.size() - 1; j++) {
    if (strs[j + 1].length() <= i || strs[j][i] != strs[j + 1][i]) {
    return s;
    }
    }
    s.push_back(strs[0][i]);
    }
    return s;
    }
    };
    • 代码看起来很简洁,但我认为,代码还应该有改进方式,比如应该先遍历出最短的那个字串,同时,求strs.size()尽量放到循环外面来,因为其是一个常量,在内层循环中,如果字串数组很大,就会产生一定的无法消除的效率影响。同时,我更喜欢使用 ++i 代替 i++ ,因为这样,能减少一次寄存器存取。也许当数据量少时看不出来这些差距,但代码在手,能优尽优嘛!不过处理了这些,好像就没原来的好看了~~

      LeetCodeOJ刷题之14【Longest Common Prefix】的更多相关文章

      1. 【leetcode刷题笔记】Longest Common Prefix

        Write a function to find the longest common prefix string amongst an array of strings. 题解:以strs[0]为模 ...

      2. leetCode练题——14. Longest Common Prefix

        1.题目 14. Longest Common Prefix   Write a function to find the longest common prefix string amongst a ...

      3. 14. Longest Common Prefix【leetcode】

        14. Longest Common Prefix Write a function to find the longest common prefix string amongst an array ...

      4. [LeetCode][Python]14: Longest Common Prefix

        # -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com'https://oj.leetcode.com/problems/longest ...

      5. Leetcode 14. Longest Common Prefix(水)

        14. Longest Common Prefix Easy Write a function to find the longest common prefix string amongst an ...

      6. LeetCode第[14]题(Java): Longest Common Prefix

        题目:最长公共前缀 难度:EASY 题目内容: Write a function to find the longest common prefix string amongst an array o ...

      7. Java [leetcode 14] Longest Common Prefix

        小二好久没有更新博客了,真是罪过,最近在看linux的东西导致进度耽搁了,所以今晚睡觉前怒刷一题! 问题描述: Write a function to find the longest common ...

      8. 14. Longest Common Prefix 最长的公共字符串开头

        [抄题]: Write a function to find the longest common prefix string amongst an array of strings. 在 " ...

      9. 14. Longest Common Prefix

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

      随机推荐

      1. 处女座和他的小姐姐(三)----数位DP

        链接:https://ac.nowcoder.com/acm/contest/329/G来源:牛客网 经过了选号和漫长的等待,处女座终于拿到了给小姐姐定制的手环,小姐姐看到以后直呼666! 处女座其实 ...

      2. jmeter+ant+jenkins生产的报告乱码

        jmeter+ant+jenkins生产的报告乱码 问题:生产报告会乱码的问题,一般是有编码格式引起的.我遇到的问题是,jmeter需要读取csv的数据作为参数.但是我们并不知道csv保存是什么编码格 ...

      3. zookeeper+dubbo简单部署方案

        1.zookeeper服务 首先,我们需要下载:zookeeper-3.4.9 解压后,在conf文件夹中添加一个配置文件zoo.cfg,内容如下: tickTime=2000 dataDir=/Us ...

      4. 使用SVN进行源码管理

        阅读目录: 1.SVN服务端配置 1.1 创建版本库 1.2 创建用户 1.3 设置用户权限 2.SVN客户端使用 2.1 向SVN服务器中导入源码 2.1.1 直接通过TortoiseSVN向SVN ...

      5. (转)10 分钟内快速构建能够承载海量数据的 nginx 日志分析与报警平台

        10 分钟内快速构建能够承载海量数据的 nginx 日志分析与报警平台 原文:https://blog.qiniu.com/archives/8713

      6. pat02-线性结构1. Reversing Linked List (25)

        02-线性结构1. Reversing Linked List (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, ...

      7. 白话SpringCloud | 第十一章:路由网关(Zuul):利用swagger2聚合API文档

        前言 通过之前的两篇文章,可以简单的搭建一个路由网关了.而我们知道,现在都奉行前后端分离开发,前后端开发的沟通成本就增加了,所以一般上我们都是通过swagger进行api文档生成的.现在由于使用了统一 ...

      8. linux安装git、node、pm2

        一.安装Git 下载:# wget https://www.kernel.org/pub/software/scm/git/git-2.9.5.tar.gz 解压:# tar -zxvf git-2. ...

      9. MVC3.0与MVC2.0的区别

        昨天面试时第一回用MVC2.0做了一个简单的增删改查功能的测试.想一下用了一年多的MVC3.0,对这两个版本不同之处做以下几点总结: 最明显的是MVC3.0较MVC2.0而言,多了Razor视图: 1 ...

      10. 项目管理系统 TAIGA 部署

        题记 使用了 MantisBT 一段时间,觉得功能太少,只局限在错误跟踪,而且操作体验比较差,界面很糟糕,很早就想将其换掉. 偶然发现一个很不错的新选择:Taiga,于是就试着将其部署下来,发现绝对是 ...