14 最长公共前缀
题目描述
编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 “”。
示例 1:
输入: ["flower","flow","flight"]
输出: "fl"
示例 2:
输入: ["dog","racecar","car"]
输出: ""
解释: 输入不存在公共前缀。
说明:
所有输入只包含小写字母 a-z 。
题目给出的接口:
class Solution {
public:
string longestCommonPrefix(vector<string>& strs) {
}
};
题目分析
将第一个字符串对象作为目标,与其他字符串进行比较,删去不同的字符即可。
代码如下:
class Solution {
public:
string longestCommonPrefix(vector<string>& strs) {
if(strs.empty()) return "";
string pre = strs[0];
for(int i = 1 ; i < strs.size() ; i++)
{
for(int j = 0 ; j < pre.length() ; j ++)
{
if(pre[j] == strs[i][j] ) continue;
else
{
pre.erase(j);//找到第一个不符合的字符位置,从pos=j处开始删除直至结尾
break;
}
}
}
return pre;
}
};