热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

剑指offer第48题无重复字符的最长子串(尺取法和动态规划)

文章目录问题描述:解题思路:代码实现:问题描述:给定一个字符串,请你找出其中不含有重复字符的最长子串的长度。

文章目录

      • 问题描述:
      • 解题思路:
      • 代码实现:






问题描述:

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

示例 1:

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

示例 2:

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

示例 3:

输入: "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3

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

题目链接:https://leetcode-cn.com/problems/longest-substring-without-repeating-characters





解题思路:

  这题使用暴力法双层循环遍历所有子串会超时,为了避免超时,使用尺取法。尺取法非常适合用于查找字符串中符合特定要求的子串。**尺取法通常是指保留数组的一对下标(起点和终点),然后根据实际情况交替推进两个端点直到得出答案。**这种操作很像尺取虫的爬行方式,故而得名。

类似的题目有:

  • 最短生成摘要
  • hiho字符串





代码实现:

import java.util.HashSet;public class text03无重复字符的最长子串 {public static void main(String[] args) {String str &#61; "dvdf";System.out.println(lengthOfLongestSubstring(str));}public static int lengthOfLongestSubstring(String s) {int res &#61; 0;char[] arr &#61; s.toCharArray();int star &#61; 0;int end &#61; 0;while(star<&#61;end && end<arr.length){HashSet<Character> set &#61; new HashSet<Character>();for(int i&#61;star; i<&#61;end; i&#43;&#43;){set.add(arr[i]);}if(set.size()&#61;&#61;(end-star&#43;1)){ //无重复if(set.size()>res){res &#61; set.size();}end&#43;&#43;;}else{ //有重复star&#43;&#43;;}}return res;}
}

提交结果&#xff1a;
在这里插入图片描述




  上面的解法可以优化&#xff0c;右指针的遍历不变&#xff0c;左指针的遍历可以进行优化。我们可以在右指针遍历的时候记录字符出现的最后位置。假设右指针当前在的位置是j&#xff0c;当左指针移动时我们可以直接将左指针移动到上一次字符s[j]最后出现的位置i&#xff08;注意要与左指针原来的位置进行比较&#xff0c;因为字符最后出现的位置不一定更靠后&#xff09;&#xff1b;因为再左指针移动到i位置之前都是会出现重复的&#xff0c;所以可以直接移动到i位置。这样可以加快了左指针的移动速度&#xff0c;减少了重复子串的判断。

代码如下&#xff1a;

public int lengthOfLongestSubstring(String s) {int res &#61; 0;char[] arr &#61; s.toCharArray();Map<Character,Integer> dic &#61; new HashMap<Character, Integer>(); //记录字符最后出现的位置。//j表示右指针&#xff0c;i表示左指针int i &#61; -1;for(int j&#61;0; j<arr.length; j&#43;&#43;) {if(dic.containsKey(arr[j])) {i &#61; Math.max(dic.get(arr[j]), i); //更细左指针,注意要比较&#xff0c;因为字符最后出现的位置不一定更靠后}dic.put(arr[j], j); //记录字符出现的组后位置res &#61; Math.max(res, j-i); }return res;}

提交结果&#xff1a;
在这里插入图片描述
这个优化的方法本质上和动态规划右类似的地方。

参考文章&#xff1a;
双指针和动态规划


推荐阅读
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • HashMap的相关问题及其底层数据结构和操作流程
    本文介绍了关于HashMap的相关问题,包括其底层数据结构、JDK1.7和JDK1.8的差异、红黑树的使用、扩容和树化的条件、退化为链表的情况、索引的计算方法、hashcode和hash()方法的作用、数组容量的选择、Put方法的流程以及并发问题下的操作。文章还提到了扩容死链和数据错乱的问题,并探讨了key的设计要求。对于对Java面试中的HashMap问题感兴趣的读者,本文将为您提供一些有用的技术和经验。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • 开发笔记:Java是如何读取和写入浏览器Cookies的
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了Java是如何读取和写入浏览器Cookies的相关的知识,希望对你有一定的参考价值。首先我 ... [详细]
  • JDK源码学习之HashTable(附带面试题)的学习笔记
    本文介绍了JDK源码学习之HashTable(附带面试题)的学习笔记,包括HashTable的定义、数据类型、与HashMap的关系和区别。文章提供了干货,并附带了其他相关主题的学习笔记。 ... [详细]
  • 模板引擎StringTemplate的使用方法和特点
    本文介绍了模板引擎StringTemplate的使用方法和特点,包括强制Model和View的分离、Lazy-Evaluation、Recursive enable等。同时,还介绍了StringTemplate语法中的属性和普通字符的使用方法,并提供了向模板填充属性的示例代码。 ... [详细]
  • 本文介绍了Java中Hashtable的clear()方法,该方法用于清除和移除指定Hashtable中的所有键。通过示例程序演示了clear()方法的使用。 ... [详细]
  • 本文整理了Java面试中常见的问题及相关概念的解析,包括HashMap中为什么重写equals还要重写hashcode、map的分类和常见情况、final关键字的用法、Synchronized和lock的区别、volatile的介绍、Syncronized锁的作用、构造函数和构造函数重载的概念、方法覆盖和方法重载的区别、反射获取和设置对象私有字段的值的方法、通过反射创建对象的方式以及内部类的详解。 ... [详细]
  • Java中包装类的设计原因以及操作方法
    本文主要介绍了Java中设计包装类的原因以及操作方法。在Java中,除了对象类型,还有八大基本类型,为了将基本类型转换成对象,Java引入了包装类。文章通过介绍包装类的定义和实现,解答了为什么需要包装类的问题,并提供了简单易用的操作方法。通过本文的学习,读者可以更好地理解和应用Java中的包装类。 ... [详细]
author-avatar
勿缘无悔
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有