首页 > 其他 > 详细

Leetcode03---Longest Substring Without Repeating Characters

时间:2015-09-30 00:47:03      阅读:270      评论:0      收藏:0      [点我收藏+]

Description:

Given a string, find the length of the longest substring without repeating characters. For example, the longest substring without repeating letters for "abcabcbb" is "abc", which the length is 3. For "bbbbb" the longest substring is "b", with the length of 1.

给定一个字符串,求字符串中最长不重复的字串长度。

又是一道没有数据范围的题目,这里字符串长可以超过3w,所以暴力不可搞。最后用很巧妙的运用起点和重点位置的 顺序选择,和对字符先后出现位置的统计,来求得结果。

class Solution {

public:

    int lengthOfLongestSubstring(string s) {

        int maxLen = 0, start = -1;

        map<char, int>mapChar;

        for (int i = 0; s[i]; i ++) {

            if (mapChar.count(s[i])) {//这里学了一招,map的count方法可以统计对应类型出现的次数,不用再dt的初始化了

                start = max(start, mapChar[s[i]]);

            }

            mapChar[s[i]] = i;

            maxLen = max(maxLen, i - start);

        }

        return maxLen;

    }

};

Leetcode03---Longest Substring Without Repeating Characters

原文:http://www.cnblogs.com/luntai/p/4847594.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!