代码拉取完成,页面将自动刷新
package array_and_string
/*
14. 最长公共前缀
编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 ""。
示例 1:
输入:strs = ["flower","flow","flight"]
输出:"fl"
示例 2:
输入:strs = ["dog","racecar","car"]
输出:""
解释:输入不存在公共前缀。
提示:
1 <= strs.length <= 200
0 <= strs[i].length <= 200
strs[i] 仅由小写英文字母组成
*/
func longestCommonPrefix(strs []string) string {
// 异常参数校验
if strs == nil || len(strs) == 0 {
return ""
}
// 以第一个字符串为基准,后续的字符串依次与这个字符串进行对比
aimStr := strs[0]
// 设置后续遍历索引,之所以设置为1,是为了跳过第一个字符串
curIndex := 1
// 依次循环切片中的每一个字符串
for curIndex < len(strs) {
// 设置临时索引,维护当前循环对比的两个字符串的公共前缀长度
tempIndex := 0
// 内循环以基准字符串的长度为限
// 最长公共前缀的长度,肯定不会超过基准字符串的长度
for i, _ := range aimStr {
// 1. i < len(strs[curIndex]) 是为了防止数组越界
// 2. aimStr[i] == strs[curIndex][i] 是为了依次对比相同的字符
if i < len(strs[curIndex]) && aimStr[i] == strs[curIndex][i] {
// 如果满足上述 if 条件,则说明对比的两个字符前 i 个字符都相同
// 将临时索引 +1,维护当前对比的两个字符串的最长公共前缀
tempIndex++
} else {
// 如果不满足上述 if 条件,则直接跳出循环
break
}
}
// 每次循环完之后,按 tempIndex 截取基准字符串
// 截取后的基准字符串,即为当前最长公共前缀
aimStr = aimStr[:tempIndex]
// 将后续遍历索引 +1,继续下一次循环
curIndex++
}
// 循环完之后,基准字符串即为最长公共前缀
return aimStr
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。