14. 最长公共前缀

编写一个函数来查找字符串数组中的最长公共前缀。

如果不存在公共前缀,返回空字符串 ""。

示例 1:

输入: ["flower","flow","flight"]
输出: "fl"
示例 2:

输入: ["dog","racecar","car"]
输出: ""
解释: 输入不存在公共前缀。
说明:

所有输入只包含小写字母 a-z 。

解:

当字符串数组长度为 0 时则公共前缀为空,直接返回
令最长公共前缀 ans 的值为第一个字符串,进行初始化
遍历后面的字符串,依次将其与 ans 进行比较,两两找出公共前缀,最终结果即为最长公共前缀
如果查找过程中出现了 ans 为空的情况,则公共前缀不存在直接返回
时间复杂度:O(s)O(s),s 为所有字符串的长度之和

class Solution {
public:
    string longestCommonPrefix(vector<string>& strs) {
        string str_front;

        for(int i=0;i<strs.size();i++)
        {
            if(i==0)
            {
                str_front=strs[i];
                continue;            
            }
            int num=min(str_front.size(),strs[i].size());
            string front_tmp;
            for(int index=0;index<num;index++)
            {
                //前面不相等,后面就不用比了
                if(str_front[index]==strs[i][index])
                {
                    front_tmp+=str_front[index];
                }
                else
                {
                    break;
                }
            }
            if(front_tmp.size()==0)
            {
                return front_tmp;
            }
            else
            {
                str_front=front_tmp;
            }
        }
        return str_front;
    }
};

 

原文链接: https://www.cnblogs.com/wangshaowei/p/12507359.html

欢迎关注

微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍;

也有高质量的技术群,里面有嵌入式、搜广推等BAT大佬

    14. 最长公共前缀

原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/391261

非原创文章文中已经注明原地址,如有侵权,联系删除

关注公众号【高性能架构探索】,第一时间获取最新文章

转载文章受原作者版权保护。转载请注明原作者出处!

(0)
上一篇 2023年3月31日 上午10:31
下一篇 2023年3月31日 上午10:31

相关推荐