最长公共前缀(简单)
2020年4月17日
题目来源:最长公共前缀
编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 “”。
示例 1:
输入: [“flower”,“flow”,“flight”]
输出: “fl”
示例 2:
输入: [“dog”,“racecar”,“car”]
输出: “”
解释: 输入不存在公共前缀。
说明:
所有输入只包含小写字母 a-z 。
解题思路
用一个模板字符串,对比每个字符串,每对比一个就把模板字符串替换成这两个的公共字符串。
注意判断传入参数为空时的情况。
代码实现
class Solution {
public String longestCommonPrefix(String[] strs) {
if(strs.length==0)
return "";
String yuan=strs[0];
for(int i=1;i<strs.length;i++){
int count=0;
while(count<yuan.length() && count<strs[i].length()){
if(yuan.charAt(count)!=strs[i].charAt(count))
break;
count++;
}
yuan=yuan.substring(0,count);
if("".equals(yuan))
return "";
}
return yuan;
}
}