//
// Created by Mr.Hu on 2018/6/23.
//
// leetcode 686 repeated string match
//
// 题目要求对于字符串A、B,将字符串A定义为模式串,求最少重复拼接多少次,可以使得字符串B为拼接后字符串的子串,
// 返回重复次数,如果不存在,则返回-1。
//
// 这个题目的突破点在于:如果字符串B的size为字符串A的整数n倍,那么字符串A最小的重复次数为n或者n+1,否则为-1;
// 所以我们先将字符串A重复n次,然后判断重复后的字符串all是否包含字符串B,是则返回n;否则再将字符串A多重复一次,
// 继续判断当前字符串all是否包含字符串B,是则返回n+1,否则返回-1。
//
// 在coding过程中,了解了STL中对string判断是否为子串的另一种方法:stringname.find(substring)!=string::npos,
// 则说明substring为stringname的子串,否则不是子串。
//
1 |
|