请从字符串中找出一个最长的不包含重复字符的子字符串,计算该最长子字符串的长度。php
示例 1:markdown
输入: "abcabcbb"
输出: 3
解释: 由于无重复字符的最长子串是 "abc",因此其长度为 3。spa
示例 2:指针
输入: "pwwkew"
输出: 3
解释: 由于无重复字符的最长子串是 "wke",因此其长度为 3。
请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。code
看完题的第一想法就是动态滑块orm
$maxDiffStr
,方便下次查验继续向后找,直到找到$maxDiffStr
中存在的值队列
将队列$maxDiffStr
依次弹出,直到弹出的值与当前循环的值相等字符串
此时从新计算maxLenstring
class Solution {
/** * @param String $s * @return Integer */
function lengthOfLongestSubstring($s) {
$len = strlen($s);
if ($len < 1) {
return 0;
}
$maxLen = 1;
$maxDiffStr = [$s[0]];
for ($i=1; $i < $len; $i++) {
if (in_array($s[$i], $maxDiffStr)) {
while (array_shift($maxDiffStr) !== $s[$i]) {}
}
$maxDiffStr[] = $s[$i];
$maxLen = $maxLen > count($maxDiffStr) ? $maxLen : count($maxDiffStr);
}
return $maxLen;
}
}
复制代码
看了大佬的题解,果真更好的方法还差很远it
class Solution {
/** * @param String $s * @return Integer */
function lengthOfLongestSubstring($s) {
$dic = [];
$res = 0;
$i = -1;
$len = strlen($s);
for ($j=0; $j < $len; $j++) {
if (isset($dic[$s[$j]])) {
$i = max($dic[$s[$j]], $i);
}
$dic[$s[$j]] = $j;
$res = max($res, $j-$i);
}
return $res;
}
}
复制代码
刷题打卡第一天,小菜菜在路上。。。