码迷,mamicode.com
首页 > Windows程序 > 详细

Longest Substring Without Repeating Characters (c#)

时间:2016-01-07 01:04:35      阅读:292      评论:0      收藏:0      [点我收藏+]

标签:

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.

这个问题仅理解他的意思,我就花了很久。。。智商捉急啊

给定一个字符串,求出其中有不重复字符的最长子串。

我一开始的想法是每次遇到有重复出现的字符时将之前的字符串截掉,剩下的进行递归,这样效率非常低下,而且频繁截取字符串,造成TLE

错误解法:

public int LengthOfLongestSubstring(string s) {
        string[] ss = new string[s.Length];
            int index = 0;
            int len = 0;
            for (int i = 0; i < s.Length; i++)
            {
                if (!ss.Contains(s.Substring(i, 1)))
                {
                    ss[i] = s.Substring(i, 1);
                    len++;
                }
                else
                {
                    for (int j = 0; j < ss.Length; j++)
                    {
                        if (ss[j] == s.Substring(i, 1))
                        {
                            index = j;
                            break;
                        }
                    }
                    s = s.Substring(index + 1, s.Length - index - 1);
                    int temp = LengthOfLongestSubstring(s);
                    if (temp > len)
                    {
                        len = temp;
                    }
                    break;
                }
            }
            return len;
    }

错误点①s.Substring(i, 1)可以等价于s[i],返回的是char类型

  ②递归截取剩下的进行下一次是否有重复字符的判断,造成效率低下

优秀解法:

public int LengthOfLongestSubstring(string s) {
        if (s.Length == 0)
            {
                return 0;
            }
            Hashtable osh = new Hashtable();
            int longest = 0;
            int substringStartPosition = 0;
            for (int i = 0; i < s.Length; i++)
            {
                if (!osh.ContainsKey(s[i]))
                {
                    osh.Add(s[i], i);
                }
                else if ((int)osh[s[i]] < substringStartPosition)
                {
                    osh[s[i]] = i;
                }
                else
                {
                    longest = System.Math.Max(longest, i - substringStartPosition);
                    substringStartPosition = (int)osh[s[i]] + 1;
                    osh[s[i]] = i;
                }
            }
            return System.Math.Max(s.Length - substringStartPosition, longest);
    }

思路:将每个字符和他的位置作为一个key value存储(不一定要用哈希表,只要能判断键值对即可),每当出现重复的字符时,将位置(value)更新;

记录最长的没有重复字符的长度和开始的位置,每次新的判断开始位置为有重复字符出现时的下一个字符位。

这样的好处就是不用频繁截取字符串,只需要记录相应的位置和长度。

 

Longest Substring Without Repeating Characters (c#)

标签:

原文地址:http://www.cnblogs.com/davidlidvd/p/5107928.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!