(每日一题) 力扣 14 最长公共前缀

14. 最长公共前缀题解:多方法详解与C++实现

问题描述

给定字符串数组,找出所有字符串的最长公共前缀。若不存在则返回空字符串。

示例

复制代码
输入:["flower","flow","flight"]
输出:"fl"

方法一:纵向扫描(逐字符比较)

算法思想

逐个字符比较所有字符串的同一列,直到出现不匹配字符为止。

复杂度分析

  • 时间复杂度:O(m*n)
    (m=最短字符串长度,n=字符串数量)
  • 空间复杂度:O(1)

C++实现

cpp 复制代码
class Solution {
public:
    string longestCommonPrefix(vector<string>& strs) {
        if(strs.empty()) return "";
        
        int min_len = INT_MAX;
        for(auto& s : strs) 
            min_len = min(min_len, (int)s.size());
        
        for(int j=0; j<min_len; ++j) {
            char c = strs[0][j];
            for(int i=1; i<strs.size(); ++i) {
                if(strs[i][j] != c)
                    return strs[0].substr(0,j);
            }
        }
        return strs[0].substr(0,min_len);
    }
};

方法二:横向扫描(迭代比较)

算法流程

  1. 取第一个字符串为初始前缀
  2. 依次与后续字符串比较,逐步缩短前缀

初始前缀:flower 与flow比较得flo 与flight比较得fl 最终结果fl

代码实现

cpp 复制代码
string longestCommonPrefix(vector<string>& strs) {
    if(strs.empty()) return "";
    string prefix = strs[0];
    for(int i=1; i<strs.size(); ++i){
        while(strs[i].find(prefix) != 0){
            prefix = prefix.substr(0, prefix.length()-1);
            if(prefix.empty()) return "";
        }
    }
    return prefix;
}

相关推荐
2401_841495646 分钟前
【LeetCode刷题】找到字符串中所有字母异位词
数据结构·python·算法·leetcode·数组·滑动窗口·找到字符串中所有字母异位词
橘颂TA10 分钟前
【剑斩OFFER】算法的暴力美学——寻找数组的中心下标
算法·leetcode·职场和发展·结构与算法
py有趣12 分钟前
LeetCode算法学习之鸡蛋掉落
学习·算法·leetcode
放羊郎20 分钟前
机器人自主导航方案概述
人工智能·算法·机器人·slam·建图
冷徹 .34 分钟前
Edu144 CD
c++·算法
一水鉴天1 小时前
整体设计 全面梳理复盘 之37 元级自动化引擎三体项目(Designer/Master/Transformer)划分确定 + 自用规划工具(增强版)
开发语言·算法·transformer·公共逻辑
爪哇部落算法小助手1 小时前
爪哇周赛 Round 1
c语言·c++·算法
TT哇2 小时前
【多源 BFS】3.地图中的最⾼点(medium)
算法·宽度优先
dllxhcjla2 小时前
数据结构与算法 第一天
数据结构·算法
再__努力1点2 小时前
【11】特征检测与匹配:AKAZE特征算法详解与实现
人工智能·python·opencv·算法·计算机视觉·特征提取