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

题目:


思路

1.将字符串中所包含的字符用字典来表示,刚开始时都赋值为0

2.接着去遍历字符串,找出无重复字符的最长子串输出对应长度
解题过程

1.首先将字符串转换为列表形式

2.判断

1>列表为空,返回0

2>列表由同个字符组成,返回1

3>无上述情况则列表去重 (判断字符串是否都不重复以及将字符串中包含的字符转换为字典来表示都需要用到去重操作,所以先不判断字符串中的字符都不重复),去重后:

  • 设置nums代表无重复最长子串的长度,初始为0
  • 从第一个字符开始,依次去遍历,则需要遍历 len(t)-1
  • 每次遍历的时候,需要将字典中的值全都重置,之后,每次从列表取一个值,这个值所对应的键的值+1,然后去判断对应键的键值是否等于2,等于2说明有重复值了,这趟遍历结束,遍历结束后去判断这趟遍历所得到的不重复子串是否是最长的,是则用nums来代替, 若对应键值对不等于2,则当前的不重复子符加上这个列表值

代码

python 复制代码
class Solution(object):
    def lengthOfLongestSubstring(self, s):
        """
        :type s: str
        :rtype: int
        """
        t = list(s)
        count = len(t)
        if count == 0:
            return 0
        elif t.count(t[0]) == count:
            return 1
        else:
            strs = list(set(t))
            dict1 = {}
            if len(strs) == len(t):
                return len(t)
            nums = 0
            for i in range(len(t)-1):
                for nums1 in strs:
                    dict1[nums1] = 0
                s1 = ''
                for j in s[i:]:
                    dict1[j]+=1
                    if dict1[j]==2:
                        break
                    else:
                        s1+=j
                if len(s1)> nums:
                    nums = len(s1)
            return nums
相关推荐
梦想科研社6 分钟前
【无人机设计与控制】四旋翼飞行无人机姿态控制ADRC非线性自抗扰控制Simulink仿真
算法·数学建模·matlab·无人机
妄想...37 分钟前
最大余额法,解决百分比计算相加不等于100%(扇形/饼图百分比使用的此算法)
前端·javascript·算法
JovaZou41 分钟前
[Python学习日记-21] Python 中的字符编码(上)
开发语言·python·学习
鱼跃鹰飞1 小时前
Leetcode面试经典150题-148.排序链表
算法·leetcode·链表·面试
哈团1 小时前
为解决bypy大文件上传报错—获取百度云文件直链并使用Aria2上传文件至服务器
服务器·python
wang1510386061 小时前
运行QWen2-1.5b模型时报错“RuntimeError: cutlassF: no kernel found to launch!”
python·深度学习
hummhumm1 小时前
数据库系统 第58节 数据库审计
网络·数据库·python·算法·oracle·java-ee·database
chnyi6_ya1 小时前
前端设计之 主页面、书架页面、数据分析页面
前端·python·数据分析
Code哈哈笑1 小时前
【Python 数据分析学习】Pandas的基础和应用(2)
python·学习·数据分析
张琪杭1 小时前
深度学习-目标检测(四)-Faster R-CNN
人工智能·python·深度学习·目标检测·cnn