[LeetCode] 3. Longest Substring Without Repeating Characters 最长不重复子串

[LeetCode] 3. Longest Substring Without Repeating Characters

Given a string, find the length of the longest substring without repeating characters.

Example 1:

Input: "abcabcbb"
Output: 3 
Explanation: The answer is 'abc', with the length of 3. 

Example 2:

Input: "bbbbb"
Output: 1
Explanation: The answer is 'b', with the length of 1.

Example 3:

Input: "pwwkew"
Output: 3
Explanation: The answer is 'kew', with the length of 3.


基本思路:使用去重方法set,判断是否有 字符串长度 == 去重长度 ,通过那么就是不重复子串,统计最长的一个

判断顺序:字符串 = 'abcd'

    
     abcd
     abc
     ab

     bcd
     bc

     cd

优化方法:1.每次查找长度是递减的,如果现在的 max_length > 下面要判断的子串长度,break
     2.找到一次,当前串不用再往下判断了,往下长度一定比当前小。


class Solution:
    def lengthOfLongestSubstring(self, s: str) -> int:
        if len(s) == 0 : return 0 #空串判断
        max_length = 1                      #初始值设置为1,最后没找到不同的子串就输出1
        j=0
        for x in range(len(s)-1):
            i = len(s)
            if (i-j) <= max_length:              #如果往下的最长子串已经小于max_length 退出
                break
            flag = 0
            while(i-j>max_length and flag==0):
                temp_str = s[j:i]
                temp_set = set(temp_str)
                if len(temp_str) == len(temp_set) and len(temp_set)>max_length:
                    max_length = len(temp_str)
                    flag =1                   #找到一个,退出子循环,不用再往下了,再往下一定长度短
                i-=1                       
            j+=1
        return max_length

 

心得:这题我只会用python做,上来是毫无头绪,思考了很久终于实现了自己的方法,只有最后一个用例超时没通过。看了一下最后一个字符串太长了。我也没办法了,
已经尽力,只能看别人的方法了。不过我觉得我做的也很不错了。



大佬代码,速度击败99.6% ,并且就这几行。。。
思路:循环加入元素,有相同的就把前面的截去,最后得到最长的串
EG:
  abcabcd
->abc ->bca ->cab ->abcd-> 输出4 这个算法的确可以保证遍历所有两个相同元素之间的子串 ,这种方法在最大子列和中也有应用 ,是为动态规划
class Solution:
    def lengthOfLongestSubstring(self, s: str) -> int:
        d = ""
        f = ""
        for i in range(len(s)):
            if s[i] not in f:
                f += s[i]
            else:
                if len(d) < len(f):
                    d = f
                f = f[f.index(s[i])+1::] + s[i]
        return max(len(d), len(f))

 

Java Solution
public static void func(String string) {
        String workString = "";
        String maxString = "";
        int maxLength = 0;
        for (int i = 0; i < string.length(); ++i) {
            char next = string.charAt(i);
            if (workString.contains(next + "")) {
                workString.substring(workString.indexOf(next) + 1);
            } else {
                workString += next;
                if (maxLength < workString.length()) {
                    maxLength = workString.length();
                    maxString = workString;
                }
            }
        }
        System.out.println("最大不重复字串为" + maxString);
        System.out.println("长度= " + maxLength);
    }

 











转载于:https://www.cnblogs.com/Poceer/p/10939653.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
单片微型计算机(MCU)经过多年的发展,在性能上有很大的进步,在型号上发展到上千种类,已经广泛应用于人类社会生活的各个领域。单片机课程已经成为高校计算机、自动化、测控以及电子信息工程等专业的重要课程。该课程是一门理论性和实践性都很强的课程,在实际教学中,应将理论教学和实验教学紧密结合。学生在掌握理论知识之余,必须通过编写程序、设计硬件电路、仿真、调试这一系列的实验过程,才能更好地掌握单片机的结构原理和应用技能。随着单片机及其接口技术的飞速发展,目前市场上供应的编程仿真实验资源并不能完全满足高校单片机课程教与学的需求,构建低成本、技术先进、源码公开的单片机编程仿真实验系统,对我国单片机课程的教学和单片机领域人才的培养具有重要的现实意义。 本论文结合目前教学中对单片机编程仿真实验系统的实际需求,采用模块化结构设计思想,精心设计和开发了单片机编程仿真实验系统。该单片机编程仿真实验系统由PC机端单片机编程控制软件和单片机编程仿真实验板两部分组成。PC机端的单片机编程控制软件可以自动检测到连接到单片机编程仿真实验板上的单片机,控制单片机编程器擦除、写入、读出、校验目标单片机ROM中的程序,以十六进制文件(.HEX文件)格式显示在控制界面内;单片机仿真实验系统能够把写入单片机的程序实时地运行,并呈现实际运行效果。单片机编程控制软件和单片机仿真实验板组成一个完整的单片机编程仿真实验系统。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值