题目描述
给你一个字符串 s 和一个字符串数组 words ,请你判断 s 是否为 words 的 前缀字符串 。 字符串 s 要成为 words 的 前缀字符串 ,需要满足:s 可以由 words 中的前 k(k 为 正数 )个字符串按顺序相连得到,且 k 不超过 words.length 。 如果 s 是 words 的 前缀字符串 ,返回 true ;否则,返回 false 。
Example 1:
输入:s = “iloveleetcode”, words = [“i”,”love”,”leetcode”,”apples”] 输出:true 解释: s 可以由 “i”、”love” 和 “leetcode” 相连得到。
Example 2:
输入:s = “iloveleetcode”, words = [“apples”,”i”,”love”,”leetcode”] 输出:false 解释: 数组的前缀相连无法得到 s 。
Constraints:
- 1 <= words.length <= 100
- 1 <= words[i].length <= 20
- 1 <= s.length <= 1000
- words[i] 和 s 仅由小写英文字母组成
解题思路
- 暴力检查
C++代码
class Solution {
public:
bool isPrefixString(string s, vector<string>& words) {
int pos = 0;
for(auto& i : words){
for(int t = 0; t < i.size(); t++){
if(t != i.size() - 1 && pos == s.size() - 1){
return false;
}
if(pos < s.size() && i[t] != s[pos]){
return false;
}
pos++;
if(pos == s.size()){
return true;
}
}
}
// 如果到最后 还没完成
return false;
}
};