14. Longest Common Prefix最长公共字符串前缀
2017-09-06 19:26
381 查看
题目:Write a function to find the longest common prefix string amongst an array of strings.
大意:写一个函数实现以下功能:在字符串数组中找到最长的公共字符串前缀
例如:如果String [ ] strs = {"ant","an",
"and", "anut"}那么最长公共字符串前缀“an”
解决方法:可以先找到数组中长度最短的字符串min_str及其长度min,然后用pattern记录由长到短的min_str,即拿min_str与数组中的每一个字符串的前min个字符进行比较,如果一直相等,说明min_str即是最长词前缀,否则就将pattern更新为min_str的前min-1个字符,再依次进行比较。如果没有公共字符串,则返回一个空的字符串。
if(strs.length==0){
return "";
}
//min用于记录数组中字符串最小的长度
int min = Integer.MAX_VALUE;
//min_str用于记录最小长度的字符串
String min_str = "";
for(int i=0;i<strs.length;i++){
if(min>strs[i].length()){
min_str = strs[i];
min = strs[i].length();
}
}
if(min==0){return "";}
for(int i=min;i>=0;i--){
String pattern = min_str.substring(0, i);
int j=0;
for(j=0;j<strs.length;j++){
if(strs[j].substring(0, i).equals(pattern)){
continue;
}else break;
}
/**
* 如果完成一个pattern与所有的字符串的比较,
* 说明pattern是所有字符串的词前缀,就返回这个pattern
*/
if(j==strs.length){
return pattern;
}
}
大意:写一个函数实现以下功能:在字符串数组中找到最长的公共字符串前缀
例如:如果String [ ] strs = {"ant","an",
"and", "anut"}那么最长公共字符串前缀“an”
解决方法:可以先找到数组中长度最短的字符串min_str及其长度min,然后用pattern记录由长到短的min_str,即拿min_str与数组中的每一个字符串的前min个字符进行比较,如果一直相等,说明min_str即是最长词前缀,否则就将pattern更新为min_str的前min-1个字符,再依次进行比较。如果没有公共字符串,则返回一个空的字符串。
if(strs.length==0){
return "";
}
//min用于记录数组中字符串最小的长度
int min = Integer.MAX_VALUE;
//min_str用于记录最小长度的字符串
String min_str = "";
for(int i=0;i<strs.length;i++){
if(min>strs[i].length()){
min_str = strs[i];
min = strs[i].length();
}
}
if(min==0){return "";}
for(int i=min;i>=0;i--){
String pattern = min_str.substring(0, i);
int j=0;
for(j=0;j<strs.length;j++){
if(strs[j].substring(0, i).equals(pattern)){
continue;
}else break;
}
/**
* 如果完成一个pattern与所有的字符串的比较,
* 说明pattern是所有字符串的词前缀,就返回这个pattern
*/
if(j==strs.length){
return pattern;
}
}
相关文章推荐
- 每日一练之Longest Common Prefix【LeetCode No.14】——求字符串的最长公共前缀
- Lettcode_14_Longest Common Prefix——查找字符串数组中最长公共前缀字符串
- 14. Longest Common Prefix (计算一组字符串最长公共前缀)
- Leetcode#14. Longest Common Prefix (最长公共前缀字符串)
- longest-common-prefix 求字符串数组的最长公共前缀
- bzoj1014: [JSOI2008]火星人prefix Splay+二分答案与字符串Hash求最长公共前缀
- LeetCode 14. Longest Common Prefix--字符串数组元素的最长公共前缀
- leetcode-14. Longest Common Prefix(寻找字符串数组最长公共前缀)
- 寻找若干个字符串的最长公共前缀 Longest Common Prefix
- Longest Common Prefix字符串最长公共前缀问题
- [转][LeetCode]Longest Common Prefix ——求字符串的最长公共前缀
- leetCode 14.Longest Common Prefix(最长公共前缀) 解题思路和方法
- LeetCode 第十四题 Longest Common Prefix(最长公共前缀)
- 14. Longest Common Prefix(最长公共前缀)
- 寻找一个字符串数组的最长公共前缀
- Longest Common Prefix -最长公共前缀
- LeetCode 找到一个字符串数组的最长公共前缀
- leetcode 14. Longest Common Prefix-最长前缀|字符串
- 14.一组字符串的最长公共前缀
- 算法系列——Longest Common Prefix最长公共前缀