美文网首页
leetcode--day-1

leetcode--day-1

作者: zyyupup | 来源:发表于2019-12-25 21:11 被阅读0次

    题目

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

    示例

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

    解题思路

    1 .滑动窗口

    #python
    class Solution(object):
        def lengthOfLongestSubstring(self, s):
            """
            :type s: str
            :rtype: int
            """
            ans = 0
            s_t = ""
            for i in s:
                if i in s_t:
                    s_t=s_t.split(i)[-1]
                s_t += i
                ans = max(ans,len(s_t))
            return ans
    

    思想简单,效率一般

    2 桶排序?

    //c
    int lengthOfLongestSubstring(char * s){
        int start = 0, end = 0, maxlen = 0;
        char map[512] = {0};
        map[(int)*(s+start)] = 1;
        
        while( *(s+end) != 0 )
        {
            maxlen = maxlen>(end-start+1)?maxlen:(end-start+1);
            ++end;
            while( 0 != map[ (int)*(s+end) ] )//将要加入的新元素与map内元素冲突,然后循环自增start=end
            {
                map[ (int)*(s+start) ] = 0;
                   ++start;
            }
            map[(int)*(s+end)] = 1;
        }
        
        return maxlen;
    }
    

    评论中看到的,时间复杂度超过100%的人。

    相关文章

      网友评论

          本文标题:leetcode--day-1

          本文链接:https://www.haomeiwen.com/subject/qokhoctx.html