刷题日记:面试经典 150 题 DAY6

刷题日记:面试经典 150 题 DAY6

  • 392. 判断子序列
  • 167. 两数之和 II - 输入有序数组
  • 11. 盛最多水的容器
  • 15. 三数之和
  • 209. 长度最小的子数组

392. 判断子序列

原题链接 392. 判断子序列

双指针,i指向s,j指向t

  • 如果s[i]==t[j],则匹配到一个字母,两个指针都后移
  • 如果s[i]!=t[j],则指针j后移继续寻找
class Solution {
public:bool isSubsequence(string s, string t) {int i = 0, j = 0;if(s.size() == 0) return true;while(i < s.size() && j < t.size()) {if(s[i] != t[j]) {j++;if(j >= t.size()) {return false;}} else {i++, j++;if(i >= s.size()) {return true;}}}return false;}
};

167. 两数之和 II - 输入有序数组

原题链接 167. 两数之和 II - 输入有序数组
双指针本质上是对搜索空间进行某种顺序的遍历,一般都会用得上某种单调性
对于题来说,搜索空间如下所示
在这里插入图片描述

  • 选择棕色作为起点,是因为从这里出发可以仅通过(向左,向右)两个动作到达任意一个状态,。这保证了不会有答案被漏,
  • 比起爆搜来说可以提升性能的原因在于,利用单调性进行搜索的剪枝。比如我们得知当前状态比目标状态大时,就可以确定一系列状态都不可能是目标状态了。在这里插入图片描述
    从实现上来说,就是一个指针位于数列头部,一个位于尾部,两个指针逐渐向中间靠拢
class Solution {
public:vector<int> twoSum(vector<int>& numbers, int target) {for(int i = 0, j = numbers.size()-1;i < j;) {if(numbers[i]+numbers[j] == target) {return {i+1 , j+1};}if(numbers[i]+numbers[j] < target) {i++;}if(numbers[i]+numbers[j] > target) {j--;}}return {};}
};

11. 盛最多水的容器

原题链接 11. 盛最多水的容器

容积等于 两个板子相差的距离×较矮板子的的高。使用双指针,从最宽的底开始,接下里考虑移动哪个指针

  • 若移动指向较高板子的指针,则底一定变小,高也一定变小(因为高总是较低板子的高)
  • 所以只能移动指向较低板子的指针
class Solution {
public:int maxArea(vector<int>& height) {int result = 0;for(int i = 0, j = height.size()-1;i < j;) {result = max(result,(j-i)*min(height[i],height[j]));if(height[i] < height[j]) {i++;} else {j--;}}return result;}
};

15. 三数之和

爆搜 O ( N 3 ) O(N^3) O(N3),可以比较简单的想到先排序,再固定一个数就可以使用双指针了。
我一开始脑抽,想着固定中间大小的那个(老是想追求对称性导致的),直接处理重复情况处理闷了。
固定最小的数比较好做。把最小数固定其实就回到了167. 两数之和 II - 输入有序数组。注意两点

  • 最外层循环遍历到正数就可以立马停止
  • 每次移动指针时,都尽可能到达连续相同元素的尾部,防止重复的情况发生
class Solution {
public:vector<vector<int>> threeSum(vector<int>& nums) {int len = nums.size();sort(nums.begin(), nums.end());vector<vector<int>> result;for(int i = 0;i < len-2;i++) {if(nums[i] > 0) break;if(i > 0 && nums[i-1] == nums[i]) continue;for(int j = i+1, k = len-1;j < k;) {int sum = nums[i]+nums[j]+nums[k];if(sum < 0) {for(j += 1;j<k && nums[j-1]==nums[j];j++);} else if(sum>0) {for(k -= 1;j<k && nums[k+1]==nums[k];k--);} else {result.push_back({nums[i],nums[j],nums[k]});for(j += 1;j<k && nums[j-1]==nums[j];j++);for(k -= 1;j<k && nums[k+1]==nums[k];k--);}}}return result;}
};

209. 长度最小的子数组

原题链接 209. 长度最小的子数组

想象数组是一组竖杆,杆与杆之间距离不一。有个皮筋,现在是松弛状态,想要找到能让它绷紧时跨越最少的竖杆。
先给皮筋套在最左边,然后抻右端,直到皮筋紧,然后一点点松左端,直到恰好送掉,然后在抻右端,重复这个步骤

class Solution {
public:int minSubArrayLen(int target, vector<int>& nums) {int len = nums.size();int ans = len+1;int left = 0, right = 0;int length = 0;int sum = 0;while(right < len) {sum += nums[right];length++;while(sum >= target) {ans = min(ans,length);sum -= nums[left];length--;left++;}right++;}if(ans > len) return 0;return ans;}
};

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

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

相关文章

JDK1.8超详细安装教程

1、下载jdk1.8 大家可以直接去百度云盘下载&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/187N6CU9Gu4bjtOz5_cjd-A?pwd3535 提取码&#xff1a;35352、开始安装 双击下载好的.exe文件&#xff0c;点击下一步 修改安装路径&#xff0c;点击下一步 会顺带安装jre…

107 在携带请求体的情况下, hutool 将 get 请求转换为了 post 请求

前言 本问题主要是来自于同事 情况大致如下, 同样的代码 一个是测试用例, 一个是生产环境的应用, 访问同一个第三方服务, 参数什么的完全一致 但是 出现的问题就是 测试用例能够拿到正确的对方的响应, 但是 生产环境的应用 却是拿到的对方的报错 然后 我开始以为是 是否…

【CKA模拟题】学会JSONPath,精准定位Pod信息!

题干 For this question, please set this context (In exam, diff cluster name) kubectl config use-context kubernetes-adminkubernetesyou have a script named pod-filter.sh . Update this script to include a command that filters and displays the label with the…

安卓Android入门

安卓作为日常生活中不可缺少的移动操作系统&#xff0c;在5G的发展和应用过程中发挥着其重要的作用。 5G是第五代移动通信技术&#xff0c;拥有更快的速度、更高的带宽、更低的延迟和更大的连接密度。这一技术的快速发展为移动设备和应用提供了更多的可能性。 安卓和5G的关系…

Qt 多元素控件

Qt开发 多元素控件 Qt 中提供的多元素控件有: QListWidgetQListViewQTableWidgetQTableViewQTreeWidgetQTreeView xxWidget 和 xxView 之间的区别 以 QTableWidget 和 QTableView 为例. QTableView 是基于 MVC 设计的控件. QTableView 自身不持有数据. 使用QTableView 的 …

OSPF特殊区域(stub\nssa)

stub区域——只有1类、2类、3类&#xff1b;完全stub区域——只有1类、2类 NSSA区域&#xff1a;本区域将自己引入的外部路由发布给其他区域&#xff0c;但不需要接收其他区域的路由 在NSSA区域的路由器上&#xff0c;引入外部路由时&#xff0c;不会转换成5类LSA&#xff0c…

HarmonyOS系统开发ArkTS常用组件切换按钮及参数

Toggle为切换按钮组件&#xff0c;一般用于两种状态之间的切换&#xff0c;例如下图中的蓝牙开关。 Toggle组件的参数&#xff1a;Toggle(options: { type: ToggleType, isOn?: boolean }) type属性用于设置Toggle组件的类型isOn属性用于设置Toggle组件的状态selectedColor()…

51-31 CVPR’24 | VastGaussian,3D高斯大型场景重建

2024 年 2 月&#xff0c;清华大学、华为和中科院联合发布的 VastGaussian 模型&#xff0c;实现了基于 3D Gaussian Splatting 进行大型场景高保真重建和实时渲染。 Abstract 现有基于NeRF大型场景重建方法&#xff0c;往往在视觉质量和渲染速度方面存在局限性。虽然最近 3D…

docker入门(四)—— docker常用命令详解

docker 常用命令 基本命令 # 查看 docker 版本 docker version # 查看一些 docker 的详细信息 docker info 帮助命令&#xff08;–help&#xff09;&#xff0c;linux必须要会看帮助文档 docker --help[rootiZbp15293q8kgzhur7n6kvZ /]# docker --helpUsage: docker [OPTI…

【C语言】结构体类型名、变量名以及typedef

文章目录 分类判断结构体成员的使用typedef 分类判断 struct tag {char m;int i; }p;假设定义了上面这一个结构体&#xff0c;tag 就是类型名&#xff0c; p 就是变量名&#xff0c; m 和 i 就是结构体成员列表。 可以这么记&#xff0c;括号前面的是类型名&#xff0c;括号后…

【vue核心技术实战精讲】1.1 Vue开篇介绍 + 1.2 Vue的起步 和 插值表达式

文章目录 准备开始适应人群vue 框架学习路线一、vue 基础1、历史介绍2、前端框架与库的区别? 二、vue的起步 和 插值表达式Stage 1&#xff1a;下载包&#xff0c;并放入项目中Stage 2&#xff1a;编码Stage 3&#xff1a;源码 与 效果 准备开始 适应人群 有一定的HTML/CSS/…

Android仿智联详情

很久没有发文章了&#xff0c;这一年多一直在卷。最近由于疫情的原因&#xff0c;很多公司都在给员工发“毕业证”&#xff0c;我也很荣幸拿到了“毕业证”。不知道是应该开心还是桑心&#xff0c;北京最近因为疫情基本都居家办公&#xff0c;而我也开始了做简历&#xff0c;刷…

OpenCV C++ 图像处理实战 ——《物体数量计数与尺寸测量》

OpenCV C++ 图像处理实战 ——《物体数量计数与尺寸测量》 一、结果演示二、多尺度自适应Gamma矫正的低照度图像增强三、轮廓计算与尺寸测量3.1 图像二值化3.2 轮廓提取3.3 物体计数与尺寸测量四、源码测试图像下载总结一、结果演示 二、多尺度自

java数据结构与算法刷题-----LeetCode135. 分发糖果

java数据结构与算法刷题目录&#xff08;剑指Offer、LeetCode、ACM&#xff09;-----主目录-----持续更新(进不去说明我没写完)&#xff1a;https://blog.csdn.net/grd_java/article/details/123063846 文章目录 1. 左右遍历2. 进阶&#xff1a;常数空间遍历&#xff0c;升序降…

HCIA复习实验题(静态路由综合实验)

一、实验拓扑 二、实验划分 三、实验需求 如上图所见&#xff1b; 四、实验结果 1.实现内网通&#xff1b; &#xff08;1&#xff09;配置R1~R5的接口IP&#xff08;以及环回接口&#xff09;&#xff1b; R1接口&#xff1a; [R1]int GigabitEthernet 0/0/0 [R1-Gigab…

低代码 + 大模型,让业务系统智能化,加速想法落地

1 AI 时代下的应用 大模型来了&#xff0c;每个行业/领域都在融合大模型。作为低代码开发的探索者&#xff0c;今天我们来聊聊业务系统是如何融合大模型实现智能化的。 我们用百度内部实际应用场景来举例。比如请假&#xff0c;智能业务助手可以帮你&#xff1a; 了解…

从零开始写 Docker(七)---实现 mydocker commit 打包容器成镜像

本文为从零开始写 Docker 系列第七篇&#xff0c;实现类似 docker commit 的功能&#xff0c;把运行状态的容器存储成镜像保存下来。 完整代码见&#xff1a;https://github.com/lixd/mydocker 欢迎 Star 推荐阅读以下文章对 docker 基本实现有一个大致认识&#xff1a; 核心原…

Jmeter-基础元件使用(二)

一、Jmeter属性 当我们想要在不同线程组中使用某变量&#xff0c;就需要使用属&#xff0c;此时Jmeter属性的设置需要函数来进行set和get操作 1.创建set函数 2.然后采用Beanshell取样器进行函数执行 3.调用全局变量pro_id 4.将上面生成的函数字符串粘贴到另一个线程组即可…

合合信息扫描全能王亮相静安区3·15活动,AI扫描带来绿色消费新体验

保护消费者的合法权益&#xff0c;是全社会的共同责任。为优化消费环境、促进品质消费高地建设&#xff0c;打造安全优质和谐的消费环境&#xff0c;上海静安区消保委于3月15日举办静安区2024年“315”国际消费者权益日活动。 “激发消费活力&#xff0c;绿色低碳同行”是本次3…

C语言字符函数和字符串函数详解

Hello, 大家好&#xff0c;我是一代&#xff0c;今天给大家带来有关字符函数和字符串函数的有关知识 所属专栏&#xff1a;C语言 创作不易&#xff0c;望得到各位佬们的互三呦 一.字符函数 在C语言中有一些函数是专门为字符设计的&#xff0c;这些函数的使用都需要包含一个头文…