Leetcode挑战题——Repeated String Match
来源:互联网 发布:淘宝售后入口多久关闭 编辑:程序博客网 时间:2024/05/16 02:31
Repeated String Match
Given two strings A and B, find the minimum number of times A has to be repeated such that B is a substring of it. If no such solution, return -1.
For example, with A = "abcd" and B = "cdabcdab".
Return 3, because by repeating A three times (“abcdabcdabcd”), B is a substring of it; and B is not a substring of A repeated two times ("abcdabcd").
Note:
The length of A
and B
will be between 1 and 10000.
<?php $str1 = "abcd"; $str2 = "cdabcdab"; function repeatedStringMatch($str1,$str2,$num = 1,$a = ''){ $str1_len = strlen($str1); $str2_len = strlen($str2); //判断字符串是否符号要求 if(!in_array($str1_len, range(1, 10000)) || !in_array($str2_len, range(1, 10000))){ return 'Invalid String!'; } if($num == 1) $a = $str1; if(strstr($str1,$str2)){ return $num; }elseif($str1_len > 2*$str2_len && strstr($str1,$str2) === false){ return -1; }else{ $str1 .= $a; return repeatedStringMatch($str1,$str2,++$num,$a);//递归调用函数,累加重复数,注意这里不能用$num++ } } echo repeatedStringMatch($str1,$str2);?>
结果:3
若有不对之处,希望各位批评指正,谢谢!
阅读全文
0 0
- Leetcode挑战题——Repeated String Match
- Leetcode | Repeated String Match
- leetcode 686 Repeated String Match
- leetcode 686. Repeated String Match
- leetcode 686. Repeated String Match
- leetcode 686. Repeated String Match
- 【LeetCode】686. Repeated String Match
- leetcode 686. Repeated String Match
- Leetcode-686. Repeated String Match(string)
- LeetCode Weekly Contest 52 Repeated String Match(string)
- 686. Repeated String Match
- 686. Repeated String Match
- leetcode题解-686. Repeated String Match && 38. Count and Say
- [LC]686. Repeated String Match
- LWC 52:686. Repeated String Match
- Repeated String Match问题及解法
- leetcode_686.Repeated String Match ? 待解决
- LeetCode——Repeated DNA Sequences
- 算法竞赛入门经典(第二版)第三章课后习题(1-4)未完待续
- OpenCV找出最小外接矩形
- @property
- codeforces 46D Parking Lot(线段树 区间合并)
- 素数筛选法 NITOJ--127
- Leetcode挑战题——Repeated String Match
- [BZOJ2338][HNOI2011]数矩形
- Linkit ONE开发板实验01-闪灯程序
- 30 多年的编码经验总结成 10 条最佳实践
- Linux Shell经典面试题(其一)
- Java逆向之利用lua动态替换java中的代码
- hello world
- Linux 新开terminal自动source 文件
- 【未完成】常微分实验3.3:解 & 连续的初值 & 可微性定理