zoukankan      html  css  js  c++  java
  • 刷题-力扣-3

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

    题目链接

    来源力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/longest-substring-without-repeating-characters/
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    题目描述

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

    输入: s = "abcabcbb"
    输出: 3 
    解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
    

    示例 2:

    输入: s = "bbbbb"
    输出: 1
    解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。
    

    示例 3:

    输入: s = "pwwkew"
    输出: 3
    解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。
         请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。
    

    示例 4:

    输入: s = ""
    输出: 0 
    

    提示:

    0 <= s.length <= 5 * 104
    s 由英文字母、数字、符号和空格组成
    

    题目分析

    1. 定义front指向字串的起始位置,rear指向rear的结束位置,front-rear+1记为字串长度。
    2. 当front每指向下一位的时候,判断front当前的字符是否和rear到front前一位中的字符重复。
    3. front和rear到front前一位中的字符重复,则rear指向重复的字符位置的下一位。
    4. 再次front++,再次执行步骤1到步骤3。
    5. 最长字串的长度就是步骤1到步骤4中front-rear+1最大的情况。

    代码

    class Solution {
    public:
        int lengthOfLongestSubstring(string s) {
            int front = 1;
            int rear = 0;
            int max = 0;
            if(s.length() == 1) return 1;
            while(front < s.length()) {
                for(int i = rear; i < front; i++) {
                    if(s[i] == s[front]) {
                        rear = i + 1;
                        break;
                    }
                }
                int fake = front - rear + 1;
                if(fake > max) max = fake;
                front++;
            }
            return max;
            
        }
    };
    

    用时23min

  • 相关阅读:
    HTTP协议学习笔记
    linux对文件某列求和
    mongodb拆库分表脚本
    mongodb基础应用
    mongodb实现对某列求和SUM
    员工价值——如何体现自己价值,如何被自己的领导认可
    使用MySQLMTOP监控MySQL性能(二)
    使用MySQLMTOP监控MySQL性能(一)
    apache+tomcat实现session共享
    apache+tomcat负载均衡3种实现方式
  • 原文地址:https://www.cnblogs.com/HanYG/p/14076076.html
Copyright © 2011-2022 走看看