leetcode题目分类_最长前缀匹配例题

leetcode题目分类_最长前缀匹配例题原题链接编写一个函数来查找字符串数组中的最长公共前缀。如果不存在公共前缀,返回空字符串 “”。示例 1:输入:strs = [“flower”,”flow”,”flight”]输出:”fl”示例 2:输入:strs = [“dog”,”racecar”,”car”]输出:””解释:输入不存在公共前缀。 提示:0 <= strs.length <= 2000 <= strs[i].length <= 200strs[i] 仅由小写英文字母组成题解分

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

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

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

示例 1:

输入:strs = ["flower","flow","flight"]
输出:"fl"
示例 2:

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

提示:

0 <= strs.length <= 200
0 <= strs[i].length <= 200
strs[i] 仅由小写英文字母组成

题解

  1. 分治,时间复杂度O(mn)
class Solution { 
   
public:
    string com(string a,string b){ 
   
        int len = min(a.size(),b.size());
        int i = 0;
        while(i < len && a[i] == b[i])i ++;
        return a.substr(0,i);
    }
    string div(vector<string> &strs,int l,int r){ 
   
        if(l < r){ 
   
            int mid = l + r >> 1;
            string left = div(strs,l,mid);
            string right = div(strs,mid + 1,r);
            int len = min(left.size(),right.size());
            int i = 0;
            while(i < len && left[i] == right[i])i ++;
            return left.substr(0,i);
        }else return strs[l];
    }
    string longestCommonPrefix(vector<string>& strs) { 
   
        if(!strs.size())return "";
        return div(strs,0,strs.size() - 1);
    }
};
  1. 二分,时间复杂度O(mnlogm)
class Solution { 
   
public:
    bool check(vector<string>strs,int x){ 
   

        for(int i = 0;i <= x;i ++){ 
   
            for(int j = 1;j < strs.size();j ++){ 
   
                if(strs[j][i] != strs[0][i])return false;
            }
        }
        return true;
    }
    int min(int x,int y){ 
   
        return x < y ? x : y;
    }
    string longestCommonPrefix(vector<string>& strs) { 
   
        if(!strs.size())return "";
        int mlen = strs[0].size();
        for(int i = 1;i < strs.size();i ++)mlen = min(mlen,strs[i].size());
        int l = -1,r = mlen - 1;
        while(l < r){ 
   
            int mid = (l + r + 1)>> 1;
            if(check(strs,mid))l = mid;
            else r = mid - 1;
        }
        return strs[0].substr(0,l + 1);
    }
};
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168886.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Oracle/Mysq数据库隔离级别设置

    Oracle/Mysq数据库隔离级别设置1.Oracle数据库的事物隔离级别设置    设置一个事物的隔离级别:SETTRANSACTIONISOLATIONLEVEL[READCOMMITED|SERIALIZABLE|READONLY];    设置一个会话的隔离级别:ALTERSESSIONSETISOLATION_LEVEL[READCOMMITTED|SERIAL…

    2022年5月25日
    40
  • 【原创】三星、镁光、海力士内存颗粒命名规则摘录

    【原创】三星、镁光、海力士内存颗粒命名规则摘录 

    2022年6月22日
    112
  • 树莓派接口定义「建议收藏」

    树莓派接口定义「建议收藏」树莓派接口定义GPIODSI显示端口CSI摄像头接口MicroSD插槽HDMI/USB/Network接口MicroUSB电源接口/3.5mm音频输出接口GPIOGPIO(通用输入/输出接口)是树莓派重要的功能接口,它相当于Arduino上的GPIO引脚。这些引脚可以用于程序中读取电路中的电信号,也可以为控制电路提供电信号。使用GPIO时要非常小心,因为GPIO容易损坏,它使用…

    2022年6月1日
    58
  • [译]MDX 介绍

    [译]MDX 介绍关于MDXMDX(MultiDimensionaleXpressionlanguage)是非常强大的工具,可以将你的多维数据库/cube发挥到极致.本文会覆盖MDX基础,并且希望能使你对

    2022年8月1日
    8
  • html完整网页实例简单_html简单网页代码解读

    html完整网页实例简单_html简单网页代码解读要完成一个网页的制作其实本质上是很简单的,本实例适合于初学HTML的同学。该实例里面有设置了css的样式设置,有div的样式格局,同样的也有js的动画效果,这个实例比较全面,有助于同学的学习。本实例仅供参考,其他行为自负。本实例分为四篇来观看。一共有一个HTML文件,三个css样式表,三个js,有16张图片。其中img里面的图片可以自行下载,或用本实例里面的图片。测试项目是建议大家用谷歌…

    2022年9月23日
    1
  • jsonObject [通俗易懂]

    jsonObject [通俗易懂]JSON就是一串字符串只不过元素会使用特定的符号标注。{"age":14;"name":“lisi”}这就是一个对象了json数组含有多个json对

    2022年7月4日
    24

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号