算法(TS):最长公共前缀

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

示例 1:

输入:strs = "flower","flow","flight"

输出:"fl"

示例 2:

输入:strs = "dog","racecar","car"

输出:""

解释:输入不存在公共前缀。

提示:

1 <= strs.length <= 200

0 <= strsi.length <= 200

strsi 仅由小写英文字母组成

解法一

假设第0个元素是公共前缀,记为 prefix,从数组的第1个元素开始遍历,每得到一个元素 str,用内层循环让 str 与 prefix 同位置的字符对比,当对比到不相同的字符时,推出内层循环,将 prefix 改为 str 与 prefix 公共部分

ts 复制代码
function longestCommonPrefix(strs: string[]): string {
    let prefix = strs[0]
    for(let i = 1; i < strs.length; i++) {
        if (!prefix) {
            break
        }
        const str = strs[i]
        let j = 0
        while(prefix[j] && str[j]) {
            if (prefix[j] !== str[j]) {
                break
            }
            j++
        }

        prefix = prefix.slice(0,j)             
    }
    return prefix
};

解法二

与解法一思路一样,只是用 str.indexOf(prefix) 修改内层 while 循环中 prefix 与 str 的匹配

ts 复制代码
function longestCommonPrefix(strs: string[]): string {
    let prefix = strs[0]
    for(let i = 1; i < strs.length; i++) {
        if (!prefix) {
            break
        }
        const str = strs[i]
        while(str.indexOf(prefix) !== 0) {
            prefix = prefix.slice(0,-1)
        }            
    }
    return prefix
};

解法一假定 prefix 的最小与 str 匹配,解法二假定 prefix 的最大与 str 匹配

相关推荐
Shan12054 小时前
无向图的Hierholzer算法流程(二)
算法
gihigo19984 小时前
基于蒙特卡洛的异常值剔除(RANSAC + MC置信区间)—MATLAB实现
开发语言·算法·matlab
Asize4 小时前
数组数据结构底层:从灵活到陷阱
前端·javascript·算法
hairenwangmiao5 小时前
B4041 [GESP202409 四级] 区间排序
算法·排序
人道领域5 小时前
【LeetCode刷题日记】47.全排列Ⅱ
java·开发语言·算法·leetcode
漂流瓶jz5 小时前
UVA-1606 两亲性分子 题解答案代码 算法竞赛入门经典第二版
数据结构·算法·向量·aoapc·算法竞赛入门经典·atan2·浮点
Navigator_Z5 小时前
LeetCode //C - 1095. Find in Mountain Array
c语言·算法·leetcode
不会就选b6 小时前
算法日常・每日刷题--<二分查找>1
算法
「維他檸檬茶」6 小时前
大模型算法学习2026.6.13
学习·算法
叫我:松哥6 小时前
基于Python的共享单车租赁数据分析与预测系统,技术栈flask+boostrap+随机森林+XGBoost
人工智能·python·深度学习·算法·随机森林·数据分析·flask