题解 | #最长公共前缀#

最长公共前缀

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

W:
前缀是从第一个位置开始的对应位置必须相同
暴力解法,从第一个字符串开始遍历,然后比较后面对应位置的字符串是否相同
不相同可以直接返回字符串
N
判断后面字符串需要注意边界判断 i==strs[j].size()
strs[0].substr(0,i);//note 是对单个字符串取的
如果都相同记得返回第一字符串

class Solution {
public:
    /**
     * 
     * @param strs string字符串vector 
     * @return string字符串
     */
    string longestCommonPrefix(vector<string>& strs) {
        // write code here
        int len=strs.size();
        if(len==0) return "";
        for(int i=0;i<strs[0].size();i++){//遍历第一个字符串的长度
            char temp=strs[0][i];
            for(int j=1;j<len;j++){
                 //比较每个字符串该位置是否和第一个相同
                if(i==strs[j].size()|| strs[j][i]!=temp){//note i==strs[j].size()
                    return strs[0].substr(0,i);//note 是对单个字符串取的
                }
            }
        }
         //后续字符串有整个字一个字符串的前缀
        return strs[0];
    }
};
全部评论

相关推荐

双尔:反手回一个很抱歉,经过慎重考虑,您与我的预期暂不匹配,感谢您的投递
点赞 评论 收藏
分享
11-04 19:05
已编辑
东莞城市学院 单片机
不知道怎么取名字_:你这个要实习两年?哪有这么久的,感觉就是即使你毕业了,但还按实习的话,是不是不用给你缴社保公积金啥的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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