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

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

3. 无重复字符的最长子串(中等)

在这里插入图片描述

在这里插入图片描述

方法:滑动窗口 + 哈希表

思路

  • 这道题主要用到思路是:滑动窗口

  • 什么是滑动窗口?

  • 其实就是一个队列,比如例题中的 abcabcbb,进入这个队列(窗口)为 abc 满足题目要求,当再进入 a,队列变成了 abca,这时候不满足要求。所以,我们要移动这个队列!

  • 如何移动?

  • 我们只要把队列的左边的元素移出就行了,直到满足题目要求!

  • 一直维持这样的队列,找出队列出现最长的长度时候,求出解!

代码

class Solution {
public:int lengthOfLongestSubstring(string s) {int ans = 0;int left = 0;unordered_set<char> lookup;for(int i=0; i<s.size(); ++i) {// 说明该字符重复.// 不断删除最左边的元素,直到将重复元素移出窗口while(lookup.find(s[i]) != lookup.end()) {lookup.erase(s[left]);left ++;}ans = max(ans, i - left + 1);lookup.insert(s[i]);}return ans;}
};

参考资料

  1. 滑动窗口
http://www.lryc.cn/news/150034.html

相关文章:

  • 苹果macOS 14开发者预览版Beta 7发布 新增超过100款视频壁纸和屏保
  • Redis 7 第五讲 事务、管道、发布订阅 过渡篇
  • [SpringBoot3]视图技术Thymeleaf
  • wangluobiancheng
  • 大数据之hadoop入门
  • 浅谈多人游戏原理和简单实现。
  • 活动预告 | 龙智、紫龙游戏与JFrog专家将出席龙智DevSecOps研讨会,探讨企业大规模开发创新
  • 米每秒和千米每小时的换算
  • js实现图形验证码
  • 一句话画出动漫效果
  • 【openGauss2.1.0 TPC-C数据导入】
  • vue+elementui表格导出
  • 掌握前端利器:JavaScript页面渲染高阶方法解析与实战
  • 面试题——网络IO模型
  • 【JUC基础】JUC入门基础(二)
  • Git Bash 和 Git GUI中文汉化
  • 【Ubuntu】Ubuntu常用软件部署
  • Hadoop HA模式切换
  • 自然语言处理(四):全局向量的词嵌入(GloVe)
  • Flink中RPC实现原理简介
  • ELK安装、部署、调试(五)filebeat的安装与配置
  • Python数据分析案例30——中国高票房电影分析(爬虫获取数据及分析可视化全流程)
  • 科技资讯|苹果Vision Pro头显申请游戏手柄专利和商标
  • Compose学习 - remember、mutableStateOf的使用
  • 字符串哈希
  • 【python】【centos】使用python杀死进程后自身也会退出
  • 【ES系列】(一)简介与安装
  • opencv案例06-基于opencv图像匹配的消防通道障碍物检测与深度yolo检测的对比
  • 练习2:88. 合并两个有序数组
  • 【代码随想录day23】不同路径