本文主要是介绍【程序员金典】子串判断,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
题目描述
现有一个小写英文字母组成的字符串s和一个包含较短小写英文字符串的数组p,请设计一个高效算法,对于p中的每一个较短字符串,判断其是否为s的子串。
给定一个string数组p和它的大小n,同时给定string s,为母串,请返回一个bool数组,每个元素代表p中的对应字符串是否为s的子串。保证p中的串长度小于等于8,且p中的串的个数小于等于500,同时保证s的长度小于等于1000。
测试样例:
[“a”,“b”,“c”,“d”],4,“abc”
返回:[true,true,true,false]
c++代码
class Substr {
public:vector<bool> chkSubStr(vector<string> p, int n, string s) {// write code herevector<bool> res(n);for(int i=0;i<n;i++){if(s.find(p[i])!=string::npos)res[i]=true;elseres[i]=false;}return res;}
};
这篇关于【程序员金典】子串判断的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!