Leetcode-Longest Substring


题目描述

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.

AC代码

#include <iostream>
#include <cstdio>
#include <cstring>
#include <string>

using namespace std;

int lengthOfLongestSubstring(string s)
{
    	int max = 0;
    	int index = -1;  //子串开始前的前一个位置,initial as -1
    	int local[256];
    	memset(local,-1,sizeof(int)*256);
    	for(int i = 0; i < s.size(); i++)
    	{
    		if(local[s[i]] > index)
    		{
    			index = local[s[i]];
    		}
    
    		if(i - index > max)
    		{
    			max = i - index;
    		}
    
    		local[s[i]] = i;
    	}
    	return max;
}

int main()
{
    	string s;
    
    #ifndef ok
    	freopen("in1.in", "r", stdin);
    	freopen("std1.out","w",stdout);
    #endif
    
    	while(cin>>s)
    		cout<<lengthOfLongestSubstring(s)<<endl;
    
    #ifndef ok
    	fclose(stdin);
    	fclose(stdout);
    #endif
    
    	return 0;
}