[LeetCode]1961. 检查字符串是否为数组前缀

数组前缀

Posted by JinFei on September 2, 2021

题目描述

给你一个字符串 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;
        }
};