题解 | 最长公共前缀

最长公共前缀

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

class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param strs string字符串vector 
     * @return string字符串
     */
    string longestCommonPrefix(vector<string>& strs) {
        // write code here
        //找到数组的最短字符串,然后从后往前截取字符串去判断是不是公共前缀 第一个符合条件的字符串就是最长的
        if(strs.size()==0) //判空
            return "";
        string str=strs[0];
        string res;
        for(int i=0;i<strs.size();i++)
        {
            if(strs[i].size()<str.size())
                str=strs[i];
        }
        //str就是最短字符串
        int count=0;
            for(int j=str.size();j>=0;j--)
            {
                count=0;
                for(int i=0;i<strs.size();i++)
                {
                    if(strs[i].substr(0,j)==str.substr(0,j)){
                        res=str.substr(0,j);
                        count++;
                    }
                }
                if(count==strs.size())
                    break;
            }
        return res;
    }
};

全部评论

相关推荐

不知道怎么取名字_:玩游戏都写到简历上了啊
投递BOSS直聘等公司6个岗位
点赞 评论 收藏
分享
A_SOUL_Off...:疑似加班加出幻觉了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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