leetcode 686. 重复叠加字符串匹配

题目如下

数据范围

题目的意思是问我们是否可以在n个a中找到b,且问你n是多少。
首先我们可以枚举n,那么n的上限在哪?
是不是当i - len(b) > len(a)时该停下来。(因为这个时候相当于开始把第(n + 1的a[0]和b[0]做比较?)
即开始循环,但是显然我们不需要这样的循环。
换句话说如果在进入循环前没找到b就代表我们找不到一个n使得a中能找到b。

通过代码

cpp 复制代码
class Solution {
public:
    int repeatedStringMatch(string a, string b) {
        int n = a.size();
        int m = b.size();
        vector<int> next(m,0);
        for(int i = 1,j = 0;i < m;i++){
            while(j > 0 && b[i] != b[i])j = next[j - 1];
            if(b[i] == b[j])j++;
            next[i] = j;
        }
        for(int i = 0,j = 0;i - m < n;i++){
            while(j > 0 && b[j] != a[i % n])j = next[j - 1];
            if(a[i % n] == b[j])j++;
            if(j == m)return i/n + 1;
        }
        return -1;
    }
};//思路中的写法 good!
相关推荐
先睡19 分钟前
Field 对象的使用
java·开发语言·算法
SuperCandyXu26 分钟前
leetcode0010 正则表达式匹配 - hard
c++·算法·leetcode
浪九天28 分钟前
支持向量机(Support Vector Machine,SVM)详细解释(带示例)
算法·机器学习·支持向量机
要好好养胃32 分钟前
C++11新特性 thread线程类
开发语言·c++
点点滴滴的记录1 小时前
算法之数据结构
算法
缘来的精彩1 小时前
Android framwork 详细开发指南
android·c++·framwork
T.Ree.1 小时前
【数据结构】_顺序表
数据结构
玉带湖水位记录员1 小时前
C++多线程编程——条件变量wait_for的返回值含义
c++
点点滴滴的记录1 小时前
算法之排序算法
java·算法·排序算法
努力的小帅2 小时前
c/c++内存管理
开发语言·c++