zoukankan      html  css  js  c++  java
  • [LintCode] Longest Common Prefix 最长共同前缀

    Given k strings, find the longest common prefix (LCP).

     
    Example

    For strings "ABCD", "ABEF" and "ACEF", the LCP is "A"

    For strings "ABCDEFG", "ABCEFG" and "ABCEFA", the LCP is "ABC"

    LeetCode上的原题,请参见我之前的博客Longest Common Prefix

    解法一:

    class Solution {
    public:    
        /**
         * @param strs: A list of strings
         * @return: The longest common prefix
         */
        string longestCommonPrefix(vector<string> &strs) {
            if (strs.empty()) return "";
            string res = "";
            for (int j = 0; j < strs[0].size(); ++j) {
                char c = strs[0][j];
                for (int i = 0; i < strs.size(); ++i) {
                    if (j >= strs[i].size() || strs[i][j] != c) return res;
                }
                res.push_back(c);
            }
            return res;
        }
    };

    解法二:

    class Solution {
    public:    
        /**
         * @param strs: A list of strings
         * @return: The longest common prefix
         */
        string longestCommonPrefix(vector<string> &strs) {
            if (strs.empty()) return "";
            for (int j = 0; j < strs[0].size(); ++j) {
                for (int i = 0; i < strs.size() - 1; ++i) {
                    if (j >= strs[i].size() || j >= strs[i + 1].size() || strs[i][j] != strs[i + 1][j]) {
                        return strs[i].substr(0, j);
                    }
                }
            }
            return strs[0];
        }
    };
  • 相关阅读:
    HTML 之轮播图
    Django 框架之 URL
    Django 框架搭建入门案例
    Python 操作 MySQL
    Python 之RabbitMQ使用
    Python 之协程
    Python 之网络编程
    Python 序列化
    Python 装饰器
    python(3)-内置函数
  • 原文地址:https://www.cnblogs.com/grandyang/p/6132943.html
Copyright © 2011-2022 走看看