题目是:
现在有一个字符串列表,和一个关键词列表,请设计一个高效算法,检测出含关键字列表中关键字(一个或多个)的字符串。
给定字符串数组A及它的大小n以及关键词数组key及它的大小m,请返回一个排好序的含关键词的字符串序号的列表。保证所有字符串长度小于等于100,关键词个数小于等于100,字符串个数小于等于200。保证所有字符串全部由小写英文字符组成。若不存在含关键字的字符串,请返回一个只含-1的数组。
测试样例:
["nowcoder","hello","now"],3,["coder",now],2
返回:[0,2]
我的代码:
class KeywordDetect:
def containKeyword(self, A, n, keys, m):
ret = []
for i,a in enumerate(A):
for k in keys:
if k in a:
ret.append(i)
break
return ret or [-1]
我的算法思想:先初始化一个列表,然后使用enumerate函数,遍历列表中的元素和下标,用i表示A的下标,用a表示A中的元素,用循环函数,判断k是否在a里面,
如果在,列表中加入k此时的下标,最后循环结束,返回ret的值,如果ret为空,则返回数组-1