leetcode每日一题-14:最长公共前缀

leetcode每日一题-14:最长公共前缀

链接

最长公共前缀



题目

在这里插入图片描述



分析

问题其实很简单,可以纵向遍历数组,然后找出来,但是有一种比较简单的办法,那就是对字符串数组进行排序,然后比较第一个和最后的一个的最长公共前缀就可以了,因为排序之后,数组中的最后一个字符串和第一个字符串是相差最大的字符串,相差最大的两个字符串求公共前缀,也一定是符合整个数组的.



代码

C++

class Solution {
public:
    string longestCommonPrefix(vector<string>& strs) {
        string res;
        sort(strs.begin(), strs.end());
        auto a = strs[0], b = strs[strs.size() - 1];
        for(int i=0 ; i<min(a.size(), b.size()) ; i++)
        {
            if(a[i] == b[i]) res += a[i];
            else break;
        }
        return res;
    }
};

Java

答案采用的不一样的做法,稍微麻烦一点

class Solution {
    
    
    public String longestCommonPrefix(String[] strs) {
    
    
        if (strs == null || strs.length == 0) {
    
    
            return "";
        }
        String prefix = strs[0];
        int count = strs.length;
        for (int i = 1; i < count; i++) {
    
    
            prefix = longestCommonPrefix(prefix, strs[i]);
            if (prefix.length() == 0) {
    
    
                break;
            }
        }
        return prefix;
    }

    public String longestCommonPrefix(String str1, String str2) {
    
    
        int length = Math.min(str1.length(), str2.length());
        int index = 0;
        while (index < length && str1.charAt(index) == str2.charAt(index)) {
    
    
            index++;
        }
        return str1.substring(0, index);
    }
}

作者:LeetCode-Solution

Guess you like

Origin blog.csdn.net/qq_45826803/article/details/121292990