题目:
编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 ""。
示例 1:
输入: ["flower","flow","flight"]
输出: "fl"
示例 2:
输入: ["dog","racecar","car"]
输出: ""
解释: 输入不存在公共前缀。
说明:
所有输入只包含小写字母 a-z 。
代码:
class Solution {
public String longestCommonPrefix(String[] args) {
int len=args.length==0?0:args[0].length();
String longPrefix="";
Set<Character> prefix=new HashSet<>();
//获取字符串最少的长度
for (int i=0;i<args.length;i++){
len=Math.min(len,args[i].length());
}
for (int i = 0; i < len; i++) {
for (int j = 0; j < args.length; j++) {
if (j<args.length-1) {
if (args[j].charAt(i)!=args[j+1].charAt(i)) {
return args[0].substring(0,i);
}
}
}
}
if (len==0) {
return "";
}
longPrefix = args[0].substring(0,len);
return longPrefix;
}
}