无重复字符的最长字符串长度-leetcode

一、题目描述

给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。

示例 1:

输入: "abcabcbb"
输出: 3
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。

示例 2:

输入: "bbbbb"
输出: 1
解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。

示例 3:

输入: "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。
     请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。

二、思路分析   1、逻辑演推      将字符串元素放入关联数组(字符 => 键),依次读取字符串元素,并判断该元素是否在字典中存在,如果存在,起始字符位置改为,重复元素的下一位      例:      字符串:asfsdf      第一步:读取a,该元素在字典中不存在, 放入字典 [‘a‘ => 0] .... 依次读取sf,并放入 [‘a‘ => 0, ‘s‘ => 1, ‘f‘ => 2]      第二步:读取s ,s在字典中存在,此时从s的下一个元素开始的字符串中,判断是否存在重复字符,即fsdf,更新s的位置信息[‘a‘ => 0, ‘s‘ => 3, ‘f‘ => 2]      第三步:重复一二步即可
三、PHP代码
class Solution {

    /**
     * @param String $s
     * @return Integer
     */
    function lengthOfLongestSubstring($s) {
        if(empty($s)) return 0;

        $dict     = [];//字典 字符 => 键
        $max      = 1;//最大字符串长度
        $startStr = 0;//起始字符

        $strlen = strlen($s);

        for( $i = 0; $i < $strlen; $i++ ) {
            $char = substr($s, $i, 1);

            if(isset($dict[$char]) && ($dict[$char] >= $startStr))
            {
                $currentlen = $i - $startStr;
                $startStr = $dict[$char] + 1;

                $max = $max < $currentlen ? $currentlen : $max;           

            } else if($i == $strlen - 1) {
                $currentlen = $i - $startStr + 1;
                $max = $max < $currentlen ? $currentlen : $max;
            } 

            $dict[$char] = $i;
        }

        return $max;
    }
}

  

原文地址:https://www.cnblogs.com/qbyyqhcz/p/10496511.html

时间: 2024-08-30 13:55:53

无重复字符的最长字符串长度-leetcode的相关文章

无重复字符的最长字符串的长度

var lengt = function(s) { let max = 0; let arr = []; for(let i=0,l=s.length;i<l;i++){ let char=s[i]; let index = arr.indexOf(char); if(index!==-1){ arr.splice(0,index + 1); } arr.push(char); if(arr.length > max){ max = arr.length; } } console.log('m

【Leetcode】【Longest Substring Without Repeating Characters】【无重复字符的最长子串】【C++】

题目:给定一字符串,求其无重复字符的最长子串长度. 思路:for循环一次,时间复杂度为O(N).字符的ascii值为32~126.start表示当前无重复字符子串的初始位置,初始值为0:可定义一个位置数组pos[128]表示for循环索引到当前位置时相应的字符对应的位置.若当前字符s[i](其ascii值为cur_pos),若pos[cur_pos]>=start,说明在start之后已有该字符s[i],则以start开始的子串第一次遇到重复字符,打住.判断当前长度是否大于max_len,若大于

QA:无重复字符的最长子串

无重复字符的最长字串 leetcode地址:https://leetcode-cn.com/problems/longest-substring-without-repeating-characters/ 题目描述: 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例: 输入: "abcabcbb" 输出: 3 解决思路: 使用map  lastOccured[byte]int 记录字符和字符最后出现的下标 对于字符串每个字符x: 1.lastOccured[x]不

C语言字符串之无重复字符的最长子串

题目描述 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 输入: "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3. 输入: "bbbbb" 输出: 1 解释: 因为无重复字符的最长子串是 "b",所以其长度为 1. 输入: "pwwkew" 输出: 3 解释: 因为无重复字符的最长子串是 "wke",所以其长度为

Leetcode(无重复字符的最长子串;删除排序链表中的重复元素II;加一;最后一个单词的长度;相同的树)

1.无重复字符的最长子串 这题需要用到滑动窗口法,有许多问题都可以考虑使用滑动窗口法:https://www.geeksforgeeks.org/tag/sliding-window/ 因为用c++,所以用到set容器:std::count 2.删除排序链表中的重复元素II 3.加一 1 class Solution { 2 public: 3 vector<int> plusOne(vector<int>& digits) { 4 int n=digits.size()-

Leetcode3---&gt;无重复字符的最长子串长度

题目:给定一个字符串string,找出string中无重复字符的最长子串. 举例: Given "abcabcbb", the answer is "abc", which the length is 3. Given "bbbbb", the answer is "b", with the length of 1. Given "pwwkew", the answer is "wke"

代码题(56)— 最长重复子串、无重复字符的最长子串

1.最长的重复子串 寻找一个字符串中最长的重复子串 最大后缀方法思路: 1. 用字符串指针数组保存用户输入的字符串的所有后缀字符串: 2. 将后缀字符串集合进行排序: 3. 比较相邻字符串的公共子串长度,找到长度最大值,保存相应字符串即为所求 空间复杂度:求长度为n的字符串的后缀,需要O(n)的空间复杂度  时间复杂度:产生后缀数组-时间复杂度O(N).对后缀数组排序是O(N*NlogN),第一个N表示字符串的比较,后面NlogN使用快排排序.依次检测相邻两个后缀的公共长度-时间复杂度O(N*N

[LeetCode]无重复字符的最长子串

给定一个字符串,找出不含有重复字符的最长子串的长度. 示例 1: 输入: "abcabcbb" 输出: 3 解释: 无重复字符的最长子串是 "abc",其长度为 3. 示例 2: 输入: "bbbbb" 输出: 1 解释: 无重复字符的最长子串是 "b",其长度为 1. 示例 3: 输入: "pwwkew" 输出: 3 解释: 无重复字符的最长子串是 "wke",其长度为 3.   请注

[Swift]LeetCode3. 无重复字符的最长子串 | Longest Substring Without Repeating Characters

Given a string, find the length of the longest substring without repeating characters. Examples: Given "abcabcbb", the answer is "abc", which the length is 3. Given "bbbbb", the answer is "b", with the length of 1.