编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 ""。
示例 1:
输入: ["flower","flow","flight"] 输出: "fl"
示例 2:
输入: ["dog","racecar","car"] 输出: "" 解释: 输入不存在公共前缀。
思路:先求出向量中最小的string长度,设为length,遍历vector,s[0][0] ----> s[s.size() -1 ][0],若相同,则将此字符添加至字符串r中,遍历s[0][1] -----> s[s.size()-1][1],同理,
一直到s[0][length] ------> s[s.size() - 1] [ length] .
#pragma once
#include<vector>
using namespace std;
/*
执行用时 : 20 ms, 在Longest Common Prefix的C++提交中击败了8.38% 的用户
内存消耗 : 9.5 MB, 在Longest Common Prefix的C++提交中击败了0.90% 的用户
*/
string longestCommonPrefix(vector<string>& s) {
string r = "";
if (s.empty())
return r;
if (s.size() == 1)
return s[0];
//求得vector中string最小长度
int length = s[1].size();
for (int i = 0; i < s.size(); i++)
{
int l = s[i].size();
if (l < length)
length = l;
}
//遍历向量vector,从s[i][0 -- length],最小长度
for (int i = 0; i < length; i++)
{
char t = s[0][i];
for (int j = 1; j < s.size(); j++)
{
if (t != s[j][i]) {
return r;
}
}
r.insert(r.end(), t);
}
return r;
}
原文:https://www.cnblogs.com/cyhezt/p/10513702.html