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

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

示例 1:

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

输出:"fl"

示例 2:

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

输出:""

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

提示:

1 <= strs.length <= 200

0 <= strs[i].length <= 200

strs[i] 仅由小写英文字母组成

解法一

假设第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 匹配

相关推荐
LYFlied5 小时前
【每日算法】LeetCode 153. 寻找旋转排序数组中的最小值
数据结构·算法·leetcode·面试·职场和发展
唐装鼠5 小时前
rust自动调用Deref(deepseek)
开发语言·算法·rust
ytttr8736 小时前
MATLAB基于LDA的人脸识别算法实现(ORL数据库)
数据库·算法·matlab
jianfeng_zhu8 小时前
整数数组匹配
数据结构·c++·算法
smj2302_796826528 小时前
解决leetcode第3782题交替删除操作后最后剩下的整数
python·算法·leetcode
LYFlied9 小时前
【每日算法】LeetCode 136. 只出现一次的数字
前端·算法·leetcode·面试·职场和发展
唯唯qwe-9 小时前
Day23:动态规划 | 爬楼梯,不同路径,拆分
算法·leetcode·动态规划
做科研的周师兄9 小时前
中国土壤有机质数据集
人工智能·算法·机器学习·分类·数据挖掘
来深圳10 小时前
leetcode 739. 每日温度
java·算法·leetcode
yaoh.wang10 小时前
力扣(LeetCode) 104: 二叉树的最大深度 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·跳槽