题解 | #最长公共前缀#记录

最长公共前缀

https://www.nowcoder.com/practice/28eb3175488f4434a4a6207f6f484f47

#include <queue>
class Solution {
  public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param strs string字符串vector
     * @return string字符串
     */
    string merge(string s1, string s2) {
        string ans = "";
        if (s1.empty() || s2.empty()) return ans;
        else if (s1 == s2) return s1;
        for (int i = 0; i < s1.size() && i < s2.size(); i++) {
            if (s1[i] == s2[i]) {
                ans += s1[i];
            } else {
                break;
            }
        }
        return ans;
    }
    string mergePre(vector<string>& strs, int b, int e) {

        if (b < e) {
            int mid = (b + e) / 2;
            return merge(mergePre(strs, b, mid), mergePre(strs, mid + 1, e));
        }
        else if(b==e){
            return strs[b];
        }
        else
            return nullptr;

    }
    string longestCommonPrefix(vector<string>& strs) {
        // write code here
        //归并
        if(strs.empty()) return "";
        return mergePre(strs, 0, strs.size() - 1);
    }
};

全部评论

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务