贪心-python

该博客介绍了一个Python实现的算法,用于找出给定字符串中长度最长且不包含重复字符的子串。算法通过滑动窗口优化,记录最长子串的长度并更新。在遇到重复字符时,调整子串起点,确保子串内所有字符唯一。

1、3. 无重复字符的最长子串

    def lengthOfLongestSubstring(self, s: str) -> int:
        n, max_n, temp = 0, 0, ""

        for i in s:
            if i not in temp:
                temp += i
                n += 1
            else:
                if n > max_n:
                    max_n = n
                pos = temp.index(i)
                temp = temp[pos+1:] + i
                n = len(temp)

        if n > max_n:
            max_n = n
        return max_n
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值