LeetCode刷题第3题(C#)

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

法一:

这道题用到的其实是滑动窗口。

滑动窗口算法是在特定窗口大小的数组或字符串上执行要求的操作。它可以将一部分问题中的嵌套循环转变为一个单循环,以此减少时间复杂度。

以字符串为例,滑动窗口的思路为:

  1. 使用双指针中的左右指针技巧,初始化left = right = 0,把[left,right]称为一个窗口

  2. 先不断扩大右侧的right指针,扩大窗口范围,直到窗口中所有的字符串都符合要求

比如要在【A,A,D,D,C,B,A,D,C】中找出现ABC的窗口

在第2步找到【AADDCB】

此时左侧还没动,所以从第一个A开始

  1. 停止增加右侧指针,开始增加左侧left,直到窗口中不包含ABC

很遗憾,只能移一位,保持窗口在【ADDCB】

  1. 重复第2步和第3步,直到right到达给定字符串的最右侧

==》【DDCB】==》【DDCBA】==》【CBA】==》【BA】==》【BADC】==》【ADC】

cs 复制代码
//样例输入[A,A,C,B,A],找ABC
public int GetAns(string s)
{
    int left = 0;
    int right = 0;
    int max = 0;
    int i,j;
    int length = s.Length;
    bool getSame = false;
    for(i = 0;i < length;i++)
    {
        //第一遍,空循环,right右移,变为1
        //第二遍,查找[A,A],发现有同一字符,左指针右移,右指针也右移,变为[A]
        //第三遍,查找[A,C],无,right右移
        //第四遍,查找[A,C,B],无,right右移
        //第五遍, 查找[A,C,B,A],有,left右移,变为[C,B,A]
        if(left <= right)
        {
            getSame = false;
            for(j = 0; j < right;j++)
            {
                if(s[j] == s[right])
                {
                    getSame = true;
                    break;
                }
            }
            if(getSame)
            {
                left = j+1;
            }
        }  
        max = max < (right - left + 1) ? (right - left + 1): max;
        right++;      
    }

    return max;
}

法二:

看到一个牛逼的大佬,用[255]大小数组构建了哈希表,以此实现必定无重复

并用ASCII码,存储每个字母出现的索引,太绝了

cs 复制代码
public int LengthOfLongestSubstring(string s) {
    int indexLeft   = 0;
    int indexRight  = 0;
    int len = s.Length;
    int[] hashMap = new int[255];
    int max = 0;
    while (indexRight < len)
    {
        if (hashMap[s[indexRight]] != 0)
        {
            if(hashMap[s[indexRight]] > indexLeft)
                indexLeft = hashMap[s[indexRight]];
            hashMap[s[indexRight]] = indexRight + 1;
        }
        else
        {
            hashMap[s[indexRight]] = indexRight + 1;
        }
        max = max < (indexRight - indexLeft + 1) ? (indexRight - indexLeft + 1): max;;
        indexRight++;
    }
    return max;
    }
相关推荐
小O的算法实验室28 分钟前
2025年IEEE TETCI,异构无人机取送货问题中的转运优化,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
chao1898447 小时前
基于 SPEA2 的多目标优化算法 MATLAB 实现
开发语言·算法·matlab
沪漂阿龙7 小时前
AI大模型面试题:支持向量机是什么?间隔最大化、软间隔、核函数、LinearSVC 全面拆解
人工智能·算法·支持向量机
little~钰8 小时前
倍增算法和ST表
算法
知识领航员8 小时前
蘑兔AI音乐深度实测:功能拆解、实测表现与适用场景
java·c语言·c++·人工智能·python·算法·github
薛定e的猫咪9 小时前
因果推理研究方向综述笔记
人工智能·笔记·深度学习·算法
一只机电自动化菜鸟9 小时前
一建机电备考笔记(33) 机电专业技术(起重技术-吊装方案)(含考频+题型)
经验分享·笔记·学习·职场和发展·课程设计
如何原谅奋力过但无声10 小时前
【灵神高频面试题合集06-08】反转链表、快慢指针(环形链表/重排链表)、前后指针(删除链表/链表去重)
数据结构·python·算法·leetcode·链表
平行侠10 小时前
037插入排序 - 整理扑克牌的算法
数据结构·算法