当前位置: 首页 > article >正文

力扣3题 无重复字符的最长子串 双指针(滑动窗口)

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

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

示例 1:

输入: s = “abcabcbb”

输出: 3

解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。

示例 2:

输入: s = “bbbbb”

输出: 1

解释: 因为无重复字符的最长子串是 “b”,所以其长度为 1。

示例 3:

输入: s = “pwwkew”

输出: 3

解释: 因为无重复字符的最长子串是 “wke”,所以其长度为 3。

请注意,你的答案必须是 子串 的长度,“pwke” 是一个子序列,不是子串。

提示:

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

算法思路

解法一: 暴力枚举 + 哈希表

时间复杂度: O(N2)

解法二: 使用滑动窗口解决问题

  1. 定义left = 0, right = 0

  2. 进窗口

    让字符进入哈希表.

  3. 判断

    当窗口内出现重复字符时, 出窗口, left++, 再进行判断…一直到窗口内没有重复字符

  4. 更新结果

代码

public int lengthOfLongestSubstring(String s) {
    char[] chars = s.toCharArray();
    int[] hash = new int[128];//用数组模拟哈希表, 用值表示字符出现的次数.
    int ans = 0;
    int right = 0, left = 0;
    while (right < s.length()) {
        hash[chars[right]]++;//进窗口
        while (hash[chars[right]] > 1) {//判断, 只要有重复字符, 就让left指向的字符划出窗口
            hash[chars[left++]]--;//出窗口
        }
        ans = Math.max(ans, right - left + 1);//更新结果
        right++;
    }
    return ans;
}

时间复杂度: O(N), 空间复杂度:O(N)


http://www.kler.cn/a/156811.html

相关文章:

  • uniapp实现在card卡片组件内为图片添加长按保存、识别二维码等功能
  • 开源 vGPU 方案 HAMi 解析
  • YARN WebUI 服务
  • Rust 中调用 Drop 的时机
  • 【C++】B2106 矩阵转置
  • Node.js JXcore 打包教程
  • python监控显卡显存
  • 基于yolov8-道路裂缝检测
  • zsh配置自定义快捷命令
  • 深度学习记录--初识向量化
  • 【C++ regex】C++正则表达式
  • STM32单片机项目实例:基于TouchGFX的智能手表设计(1)项目介绍及GUI界面基础
  • 应用于智慧工厂的AI边缘计算盒子+AI算法软硬一体化方案
  • Oracle(2-8)Configuring the Database Archiving Mode
  • Typora免费版安装教程(仅供学习)
  • 【vue】尚硅谷vue3学习笔记
  • Vue2学习笔记(事件处理)
  • 谈谈 .NET8 平台中对 LiteDB 的 CRUD 操作
  • 羊大师教你如何有效应对冬季流感,保护自己与家人
  • CRM实战:如何对商机阶段进行有效管理
  • 智能联动第三方告警中心,完美实现故障响应全闭环
  • 如何使用cpolar+Plex在Windows系统上搭建私人媒体影音站点公网可访问
  • 1+x网络系统建设与运维(中级)-练习3
  • 【蓝桥杯】翻硬币
  • 地方公派|商学院老师对口加拿大古德曼商学院访学交流
  • 微信小程序引入node_modules依赖