ds刷题day3|76. 最小覆盖子串、3. 无重复字符的最长子串、11. 盛最多水的容器、LCR 007. 三数之和

76. 最小覆盖子串 - 力扣(LeetCode)

        不断移动右指针,如果指针指向的元素是目标元素,则存入哈希表中。

        检查是否满足要求,如果满足,就移动左指针,并且把左指针遍历的元素移除哈希表。

class Solution {Map<Character,Integer> ori = new HashMap<>();Map<Character,Integer> cnt = new HashMap<>();public String minWindow(String s, String t) {int tlen = t.length();//生成目标元素的哈希表for(int i = 0; i < tlen; i++){char c = t.charAt(i);ori.put(c, ori.getOrDefault(c,0) + 1);   }int l = 0, r = -1;int slen = s.length();int minLen = Integer.MAX_VALUE, ansL = -1, ansR = -1;while(r < slen){r++;if(r < slen && ori.containsKey(s.charAt(r))){char relem = s.charAt(r);cnt.put(relem, cnt.getOrDefault(relem,0) + 1);}while(check() && l <=r){if(r-l+1 < minLen){minLen = r-l+1;ansL = l;ansR = r;}char lelem = s.charAt(l);if(ori.containsKey(lelem)){cnt.put(lelem,cnt.getOrDefault(lelem, 0) - 1);}l++;}} return ansL == -1? "":s.substring(ansL,ansR + 1);}public boolean check(){Iterator iter = ori.entrySet().iterator();while(iter.hasNext()){Map.Entry entry = (Map.Entry)iter.next();Character key = (Character)entry.getKey();Integer val = (Integer)entry.getValue();if(cnt.getOrDefault(key,0) < val){return false;}}return true;}
}
//被子收纳

 3. 无重复字符的最长子串 - 力扣(LeetCode)

         右指针不断向右移动,用哈希表记录已经覆盖的字符,如果遇到的下一个字符x是哈希表中包含的,则将左指针移动到上次出现该字符x的位置,并且将哈希表中左指针遍历的元素都删掉。

class Solution {public int lengthOfLongestSubstring(String s) {Map<Character,Integer> hm = new HashMap<>();int r = -1;int slen = s.length();int maxLen = 0;for(int i = 0; i < slen; i++){if(i != 0){//这里不能删除i指向的字符,因为i是更新过后的,要删除旧的hm.remove(s.charAt(i - 1));}//这部分是为了判断下一个字符是否当前哈希表已经包含了,如果已经包含,则逐个删除字符,直到哈希表不含下一个字符为止。while(r + 1 < slen && hm.containsKey(s.charAt(r + 1)) != true){hm.put(s.charAt(r + 1) , 1);r++;}//当右指针移不动的时候,更新长度。maxLen = Math.max(maxLen, r - i + 1);}return maxLen;}
}

11. 盛最多水的容器 - 力扣(LeetCode)

         当长只能缩小的时候,高必须增大,才能让面积增大。因此每次都移动比较短的高,试图让他增大。

class Solution {public int maxArea(int[] height) {int l = 0, r = height.length - 1;int res = 0;while( l < r){int area = (r-l)* Math.min(height[l],height[r]);res = Math.max(area,res);if(height[l] < height[r]){int cur = height[l];while(l < r && height[l] <= cur) l++;}else{int cur = height[r];while(l < r && height[r] <= cur) r--;}}return res;}
}

LCR 007. 三数之和 - 力扣(LeetCode)

         要理解左右指针同时往右边移动是一定是递增的,同时往左边一定是递减的。

        遍历每个元素,然后给每个元素赋予左右指针,让他们从左右不断向内靠拢,如果三数之和大于0,就把右指针左移。反之亦然。如果相等同时移动左右指针向内,如果仅移动一侧向内,仍然保持相等,那么结果一定是重复的,当然同时向内也有可能重复,因此需要判断两个指针的 下一位指向元素是否和当前指向相等。

class Solution {public List<List<Integer>> threeSum(int[] nums) {Arrays.sort(nums);List<List<Integer>> res = new LinkedList<>();for(int i = 0; i < nums.length - 2; i++){if(nums[i] > 0 ) return res;if(i > 0 && nums[i] == nums[i-1]) continue;int left = i + 1;int right = nums.length - 1;while(i >= 0 && left < right){    if(nums[i] + nums[left] + nums[right] == 0){List<Integer> tmp = new LinkedList<>();tmp.add(nums[i]);tmp.add(nums[left]);tmp.add(nums[right]);res.add(tmp);left++;right--;while(left < right && nums[left-1] == nums[left] && nums[right] == nums[right+1]){left++;right--;}}else if(nums[i] + nums[left] + nums[right] > 0){right--;}else if(nums[i] + nums[left] + nums[right] < 0){left++;}}}return res;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/498133.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

智能故障诊断和寿命预测期刊推荐

往期精彩内容&#xff1a; Python-凯斯西储大学&#xff08;CWRU&#xff09;轴承数据解读与分类处理 基于FFT CNN - BiGRU-Attention 时域、频域特征注意力融合的轴承故障识别模型-CSDN博客 基于FFT CNN - Transformer 时域、频域特征融合的轴承故障识别模型-CSDN博客 P…

Eclipse中引入NS3项目

参考资料&#xff1a; 博主&#xff1a;深度不睡觉 NS3的3.36版本将Eclipse作IDE_ns3使用eclipse-CSDN博客 从1.2安装eclipse开始 其中参考教程中省略的几点&#xff1a; 1.下载解压tar包 mkdir /Tools/Eclipse/EclipseTool # 新建目录 tar -zxvf /path/to/eclipse-cpp-20…

DAY178内网渗透之内网对抗:横向移动篇入口差异切换上线IPC管道ATSC任务Impacket套件UI插件

1.内网横向移动 1、横向移动篇-入口点分析-域内域外打点 2、横向移动篇-IPC利用-连接通讯&计划任务, 3、横向移动篇-IPC利用-命令模式&工具套件 1.1 横向移动入口知识点 收集到域内用户和凭据后&#xff0c;为后续利用各种协议密码喷射通讯上线提供条件&#xff0c;…

【Lua之·Lua与C/C++交互·Lua CAPI访问栈操作】

系列文章目录 文章目录 前言一、概述1.1 Lua堆栈 二、栈操作2.1 基本的栈操作2.2 入栈操作函数2.3 出栈操作函数2.4 既入栈又出栈的操作函数2.5 栈检查与类型转换函数2.5 获取表数据 三、实例演示总结 前言 Lua是一种轻量级的、高性能的脚本语言&#xff0c;经常被用于游戏开发…

Python爬虫教程——7个爬虫小案例(附源码)_爬虫实例

本文介绍了7个Python爬虫小案例&#xff0c;包括爬取豆瓣电影Top250、猫眼电影Top100、全国高校名单、中国天气网、当当网图书、糗事百科段子和新浪微博信息&#xff0c;帮助读者理解并实践Python爬虫基础知识。 包含编程资料、学习路线图、源代码、软件安装包等&#xff01;【…

VITUREMEIG | AR眼镜 算力增程

根据IDC发布的《2024年第三季度美国AR/VR市场报告》显示&#xff0c;美国市场AR/VR总出货量增长10.3%。其中&#xff0c;成立于2021年的VITURE增长速度令人惊艳&#xff0c;同比暴涨452.6%&#xff0c;成为历史上增长最快的AR/VR品牌。并在美国AR领域占据了超过50%的市场份额&a…

算法 class 004(选择,冒泡,插入)

选择排序&#xff1a; 刚进入 j 循环的样子 j 跳出循环后&#xff0c;b 指向最小值的坐标 然后交换 i 和 b 位置的 值 随后 i , b i , i j1; 开始新一轮的排序&#xff0c; void SelectAQort(int* arr,int size)//选择排序 {for (int i 0; i < size-1; i){ //i 的位置就是…

【Trick】获取kaggle账号的token和api(用于数据集下载)

0&#xff1a;操作背景 由于未来的科研需要用到Unet&#xff0c;但是运行学长的史山代码无法跑通&#xff0c;自己写了一个Unet并load学长的数据集效果也很差&#xff0c;于是打算从最最基础的开始&#xff0c;上github调用一个Unet并成功在公有数据集上跑一遍实例。 Unet的g…

深入理解MemCache

随着互联网应用的飞速发展&#xff0c;动态Web应用的性能问题逐渐成为开发者关注的焦点。其中&#xff0c;数据库作为系统性能的关键瓶颈&#xff0c;在用户请求量急剧增加的情况下&#xff0c;往往难以快速响应用户需求。为了解决这一问题&#xff0c;缓存技术应运而生。MemCa…

移动 APP 设计规范参考

一、界面设计规范 布局原则&#xff1a; 内容优先&#xff1a;以内容为核心进行布局&#xff0c;突出用户需要的信息&#xff0c;简化页面导航&#xff0c;提升屏幕空间利用率.一致性&#xff1a;保持界面元素风格一致&#xff0c;包括颜色、字体、图标等&#xff0c;使用户在…

redis数据结构设计

一. 数据结构简介 要搞清楚redis数据结构&#xff0c;首先需要知道和redis数据相关的三层结构&#xff1a; 五种数据类型 String&#xff08;字符串&#xff09;、List&#xff08;列表&#xff09;、Hash&#xff08;哈希&#xff09;、Set&#xff08;集合&#xff09;和 Sor…

使用npm包的工程如何引入mapboxgl-enhance/maplibre-gl-enhance扩展包

作者&#xff1a;刘大 前言 在使用iClient for MapboxGL/MapLibreGL项目开发中&#xff0c;往往会对接非EPSG:3857坐标系的地图&#xff0c;由于默认不支持&#xff0c;因此需引入mapboxgl-enhance/maplibre-gl-enhance扩展包。 在使用Vue等其他框架&#xff0c;通过npm包下载…

021-spring-springmvc

比较重要的部分 比较重要的部分 比较重要的部分 关于组件的部分 这里以 RequestMappingHandlerMapping 为例子 默认的3个组件是&#xff1a; org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping org.springframework.web.servlet.mvc.method.annotation.Requ…

使用Locust对MySQL进行负载测试

1.安装环境 pip install locust mysql-connector-python 2.设置测试环境 打开MySQL服务 打开Navicat新建查询&#xff0c;输入SQL语句 3.编写locust脚本 load_mysql.py # codingutf-8 from locust import User, TaskSet, task, between import mysql.connector import ran…

Java [后端] 开发日常记录(1)

目录 1、常用的注解 2、对字符串的处理 3、对JSON串的处理 -- The End -- 详细如下&#xff1a; 1、常用的注解 若返回的字段中有NUll&#xff0c;则不返回 JsonInclude(value JsonInclude.Include.NON_NULL) //在实体类中添加这个注解 JsonInclude(JsonInclude.Include.NON…

你有哪些Deep Learning(RNN、CNN)调参的经验?

在深度学习的实践中&#xff0c;调参是一项既艺术又科学的工作。它不仅需要理论知识的支撑&#xff0c;还需要大量的实践经验。以下是一些在RNN和CNN模型调参中积累的经验&#xff0c;希望对正在这个领域摸索的朋友们有所帮助。 1. 从成熟的开源项目开始 对于初学者来说&…

公司招产品代理,合作合同协议书怎么写?

如果你的公司招产品代理时候&#xff0c;由于合同协议不标准&#xff0c;导致客户不信任&#xff0c;或者出现过法律纠纷。这份合同协议书&#xff0c;一定能帮你解决这些问题。 标准的模版&#xff0c;各位企业老板可以直接复制套用&#xff01; 甲方&#xff08;委托方 / 产…

wxWidgets 3.2.5发布 —— 发布于2024年5月13日

稳定版3.2系列的最新版本现已在GitHub上发布&#xff0c;你可以从那里下载包含库源代码和文档的存档文件&#xff0c;以及为选定的Windows编译器&#xff08;如Microsoft Visual C、MinGW-w64和TDM-GCC&#xff09;提供的二进制文件。你还可以在线阅读此版本的更新文档&#xf…

【Ubuntu】Ubuntu server 18.04 搭建Slurm并行计算环境(包含NFS)

Ubuntu server 18.04 搭建Slurm并行计算环境&#xff08;包含NFS&#xff09; 一、Munge 认证模块 1.1、安装 munge 主节点和子节点都安装munge #安装 sudo apt update && sudo apt install munge libmunge-dev#设置开机启动 sudo systemctl enable munge sudo syste…

用css实现瀑布流布局

上效果 知识理解 column-count: 4; column-gap: 15px;实现固定四行瀑布流布局 columns: 200px auto;column-gap: 15px;由浏览器根据容器的宽度自动调整&#xff0c;尽可能一行多个200px宽度的列数 <!DOCTYPE html> <html lang"en"><head><me…