题目描述:
编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 ""
。
示例 1:
输入: ["flower","flow","flight"]
输出: "fl"
示例 2:
输入: ["dog","racecar","car"]
输出: ""
解释: 输入不存在公共前缀。
说明:
所有输入只包含小写字母 a-z
。
思路:
将数组中的字符串按字典排序数组,比较第一个,和最后一个单词,有多少前缀相同。
java:
class Solution {
public String longestCommonPrefix(String[] strs) {
if (strs.length == 0) return "";
if (strs.length == 1) return strs[0];
StringBuilder prefix = new StringBuilder();
Arrays.sort(strs);
String firstStr = strs[0];
String endStr = strs[strs.length - 1];
for (int i = 0; i < firstStr.length(); i++) {
if (firstStr.charAt(i) == endStr.charAt(i)) {
prefix.append(firstStr.charAt(i));
} else break;
}
return prefix.toString();
}
}