Problem :
Write a function to find the longest common prefix string amongst an array of strings.
If there is no common prefix, return an empty string ""
.
Solve :
Thought :
这道题属于easy的题,想要解题自然是不难,这道题有很多种算法,归根结底还是要逐个比较两个字符串的最长前缀。
一开始我写了个两个字符串匹配最长前缀的函数,在循环调用n-1次,发现耗时太多了。
查了一下才发现python中有一个find函数(类似的在java有indexof),实现的是在另一个字符串中从头开始查找给定字符串,返回最先匹配的首字符下标,否则返回-1
于是有了另一种匹配算法(上图所示):以第一个字符串作为初始值,对其他每个字符串执行以下操作,strs[i].find(当前最长前缀),如果返回值不为0,即当前最长前缀不是该字符串的前缀,则取出当前最长前缀的最后一个字符,继续执行find操作,直到当前最长前缀也是该字符串的前缀为之。最后返回当前最长前缀即可。
这个算法比之前的自己写函数逐个匹配快了一些。