题目链接
题目描述
编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 ""。
示例 1:
输入: ["flower","flow","flight"]输出: "fl"复制代码
示例 2:
输入: ["dog","racecar","car"]输出: ""解释: 输入不存在公共前缀。复制代码
说明:
所有输入只包含小写字母 a-z
。
解题方案
思路
- 标签:字符串
- 当字符串数组长度为0时则公共前缀为空,直接返回
- 令最长公共前缀ans的值为第一个字符串,进行初始化
- 遍历后面的字符串,依次将其与ans进行比较,两两找出公共前缀,最终结果即为最长公共前缀
- 如果查找过程中出现了ans为空的情况,则公共前缀不存在直接返回
- 时间复杂度:O(s),s为所有字符串的长度之和
代码
- Java版本
class Solution { public String longestCommonPrefix(String[] strs) { if(strs.length == 0) return ""; String ans = strs[0]; for(int i =1;i
- JavaScript版本
/** * @param {string[]} strs * @return {string} */var longestCommonPrefix = function(strs) { if(strs.length == 0) return ""; let ans = strs[0]; for(let i =1;i
画解
后台回复「算法」,加入天天算法群 觉得算法直击灵魂,欢迎点击在看和转发