首页 > 其他 > 详细

LeetCode14:最长公共前缀

时间:2019-03-11 23:03:11      阅读:178      评论:0      收藏:0      [点我收藏+]

编写一个函数来查找字符串数组中的最长公共前缀。

如果不存在公共前缀,返回空字符串 ""

示例 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;
}

  

LeetCode14:最长公共前缀

原文:https://www.cnblogs.com/cyhezt/p/10513702.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!