14. 最长公共前缀

14. 最长公共前缀

Show me the code

swift 复制代码
class Solution {
    func longestCommonPrefix(_ strs: [String]) -> String {
        var ret = ""
        var stop = false
        let firstString = strs.first!
        guard !firstString.isEmpty else {
        	// 首个字符串是""
            return ""
        }
        var prefix = ""
        for maxLength in 1...firstString.count {
            prefix = String(firstString.prefix(maxLength))
            for str in strs {
                if !str.hasPrefix(prefix) {
                    ret = String(firstString.prefix(maxLength - 1))
                    stop = true
                    break
                }
            }
            if stop {
                break
            }
        }
        // 首个str整个都是前缀
        if !stop {
            ret = firstString
        }
        return ret
    }
}

运行结果

相关推荐
Tisfy7 分钟前
LeetCode 1292.元素和小于等于阈值的正方形的最大边长:二维前缀和(无需二分)+抽象速懂的描述
算法·leetcode·职场和发展
程序员-King.25 分钟前
day156—回溯—组合总和(LeetCode-216)
算法·leetcode·回溯
努力学算法的蒟蒻25 分钟前
day60(1.19)——leetcode面试经典150
算法·leetcode·面试
漫随流水28 分钟前
leetcode回溯算法(216.组合总和Ⅲ)
数据结构·算法·leetcode·回溯算法
开开心心_Every34 分钟前
文件数量统计工具:支持多层文件夹数量统计
游戏·微信·pdf·excel·语音识别·swift·lisp
期末考复习中,蓝桥杯都没时间学了1 小时前
力扣刷题记录2
算法·leetcode·职场和发展
Remember_9931 小时前
【LeetCode精选算法】双指针专题一
java·数据结构·算法·leetcode
多米Domi0111 小时前
0x3f 第36天 外卖8,9,树
数据结构·python·算法·leetcode
程序员-King.1 小时前
day153—回溯—子集(LeetCode-78)
算法·leetcode·回溯·递归
wen__xvn2 小时前
代码随想录算法训练营DAY20第六章 二叉树part07
数据结构·算法·leetcode